package org.hl7.fhir.r4b.model;

/*
  Copyright (c) 2011+, HL7, Inc.
  All rights reserved.
  
  Redistribution and use in source and binary forms, with or without modification, \
  are permitted provided that the following conditions are met:
  
   * Redistributions of source code must retain the above copyright notice, this \
     list of conditions and the following disclaimer.
   * Redistributions in binary form must reproduce the above copyright notice, \
     this list of conditions and the following disclaimer in the documentation \
     and/or other materials provided with the distribution.
   * Neither the name of HL7 nor the names of its contributors may be used to 
     endorse or promote products derived from this software without specific 
     prior written permission.
  
  THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS \"AS IS\" AND \
  ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED \
  WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. \
  IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, \
  INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT \
  NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR \
  PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, \
  WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) \
  ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE \
  POSSIBILITY OF SUCH DAMAGE.
  */

// Generated on Mon, Jun 13, 2022 17:19+0300 for FHIR v4.3.0

import java.util.ArrayList;
import java.util.Date;
import java.util.List;
import org.hl7.fhir.utilities.Utilities;
import org.hl7.fhir.r4b.model.Enumerations.*;
import org.hl7.fhir.instance.model.api.IBaseBackboneElement;
import org.hl7.fhir.exceptions.FHIRException;
import org.hl7.fhir.instance.model.api.ICompositeType;
import ca.uhn.fhir.model.api.annotation.ResourceDef;
import ca.uhn.fhir.model.api.annotation.SearchParamDefinition;
import org.hl7.fhir.instance.model.api.IBaseBackboneElement;
import ca.uhn.fhir.model.api.annotation.Child;
import ca.uhn.fhir.model.api.annotation.ChildOrder;
import ca.uhn.fhir.model.api.annotation.Description;
import ca.uhn.fhir.model.api.annotation.Block;

/**
 * The EvidenceReport Resource is a specialized container for a collection of
 * resources and codable concepts, adapted to support compositions of Evidence,
 * EvidenceVariable, and Citation resources and related concepts.
 */
@ResourceDef(name = "EvidenceReport", profile = "http://hl7.org/fhir/StructureDefinition/EvidenceReport")
public class EvidenceReport extends DomainResource {

  public enum ReportRelationshipType {
    /**
     * This document replaces or supersedes the target document.
     */
    REPLACES,
    /**
     * This document notes corrections or changes to replace or supersede parts of
     * the target document.
     */
    AMENDS,
    /**
     * This document adds additional information to the target document.
     */
    APPENDS,
    /**
     * This document was generated by transforming the target document (eg format or
     * language conversion).
     */
    TRANSFORMS,
    /**
     * This document was.
     */
    REPLACEDWITH,
    /**
     * This document was.
     */
    AMENDEDWITH,
    /**
     * This document was.
     */
    APPENDEDWITH,
    /**
     * This document was.
     */
    TRANSFORMEDWITH,
    /**
     * added to help the parsers with the generic types
     */
    NULL;

    public static ReportRelationshipType fromCode(String codeString) throws FHIRException {
      if (codeString == null || "".equals(codeString))
        return null;
      if ("replaces".equals(codeString))
        return REPLACES;
      if ("amends".equals(codeString))
        return AMENDS;
      if ("appends".equals(codeString))
        return APPENDS;
      if ("transforms".equals(codeString))
        return TRANSFORMS;
      if ("replacedWith".equals(codeString))
        return REPLACEDWITH;
      if ("amendedWith".equals(codeString))
        return AMENDEDWITH;
      if ("appendedWith".equals(codeString))
        return APPENDEDWITH;
      if ("transformedWith".equals(codeString))
        return TRANSFORMEDWITH;
      if (Configuration.isAcceptInvalidEnums())
        return null;
      else
        throw new FHIRException("Unknown ReportRelationshipType code '" + codeString + "'");
    }

    public String toCode() {
      switch (this) {
      case REPLACES:
        return "replaces";
      case AMENDS:
        return "amends";
      case APPENDS:
        return "appends";
      case TRANSFORMS:
        return "transforms";
      case REPLACEDWITH:
        return "replacedWith";
      case AMENDEDWITH:
        return "amendedWith";
      case APPENDEDWITH:
        return "appendedWith";
      case TRANSFORMEDWITH:
        return "transformedWith";
      case NULL:
        return null;
      default:
        return "?";
      }
    }

    public String getSystem() {
      switch (this) {
      case REPLACES:
        return "http://hl7.org/fhir/report-relation-type";
      case AMENDS:
        return "http://hl7.org/fhir/report-relation-type";
      case APPENDS:
        return "http://hl7.org/fhir/report-relation-type";
      case TRANSFORMS:
        return "http://hl7.org/fhir/report-relation-type";
      case REPLACEDWITH:
        return "http://hl7.org/fhir/report-relation-type";
      case AMENDEDWITH:
        return "http://hl7.org/fhir/report-relation-type";
      case APPENDEDWITH:
        return "http://hl7.org/fhir/report-relation-type";
      case TRANSFORMEDWITH:
        return "http://hl7.org/fhir/report-relation-type";
      case NULL:
        return null;
      default:
        return "?";
      }
    }

    public String getDefinition() {
      switch (this) {
      case REPLACES:
        return "This document replaces or supersedes the target document.";
      case AMENDS:
        return "This document notes corrections or changes to replace or supersede parts of the target document.";
      case APPENDS:
        return "This document adds additional information to the target document.";
      case TRANSFORMS:
        return "This document was generated by transforming the target document (eg format or language conversion).";
      case REPLACEDWITH:
        return "This document was.";
      case AMENDEDWITH:
        return "This document was.";
      case APPENDEDWITH:
        return "This document was.";
      case TRANSFORMEDWITH:
        return "This document was.";
      case NULL:
        return null;
      default:
        return "?";
      }
    }

    public String getDisplay() {
      switch (this) {
      case REPLACES:
        return "Replaces";
      case AMENDS:
        return "Amends";
      case APPENDS:
        return "Appends";
      case TRANSFORMS:
        return "Transforms";
      case REPLACEDWITH:
        return "Replaced With";
      case AMENDEDWITH:
        return "Amended With";
      case APPENDEDWITH:
        return "Appended With";
      case TRANSFORMEDWITH:
        return "Transformed With";
      case NULL:
        return null;
      default:
        return "?";
      }
    }
  }

  public static class ReportRelationshipTypeEnumFactory implements EnumFactory<ReportRelationshipType> {
    public ReportRelationshipType fromCode(String codeString) throws IllegalArgumentException {
      if (codeString == null || "".equals(codeString))
        if (codeString == null || "".equals(codeString))
          return null;
      if ("replaces".equals(codeString))
        return ReportRelationshipType.REPLACES;
      if ("amends".equals(codeString))
        return ReportRelationshipType.AMENDS;
      if ("appends".equals(codeString))
        return ReportRelationshipType.APPENDS;
      if ("transforms".equals(codeString))
        return ReportRelationshipType.TRANSFORMS;
      if ("replacedWith".equals(codeString))
        return ReportRelationshipType.REPLACEDWITH;
      if ("amendedWith".equals(codeString))
        return ReportRelationshipType.AMENDEDWITH;
      if ("appendedWith".equals(codeString))
        return ReportRelationshipType.APPENDEDWITH;
      if ("transformedWith".equals(codeString))
        return ReportRelationshipType.TRANSFORMEDWITH;
      throw new IllegalArgumentException("Unknown ReportRelationshipType code '" + codeString + "'");
    }

    public Enumeration<ReportRelationshipType> fromType(PrimitiveType<?> code) throws FHIRException {
      if (code == null)
        return null;
      if (code.isEmpty())
        return new Enumeration<ReportRelationshipType>(this, ReportRelationshipType.NULL, code);
      String codeString = code.asStringValue();
      if (codeString == null || "".equals(codeString))
        return new Enumeration<ReportRelationshipType>(this, ReportRelationshipType.NULL, code);
      if ("replaces".equals(codeString))
        return new Enumeration<ReportRelationshipType>(this, ReportRelationshipType.REPLACES, code);
      if ("amends".equals(codeString))
        return new Enumeration<ReportRelationshipType>(this, ReportRelationshipType.AMENDS, code);
      if ("appends".equals(codeString))
        return new Enumeration<ReportRelationshipType>(this, ReportRelationshipType.APPENDS, code);
      if ("transforms".equals(codeString))
        return new Enumeration<ReportRelationshipType>(this, ReportRelationshipType.TRANSFORMS, code);
      if ("replacedWith".equals(codeString))
        return new Enumeration<ReportRelationshipType>(this, ReportRelationshipType.REPLACEDWITH, code);
      if ("amendedWith".equals(codeString))
        return new Enumeration<ReportRelationshipType>(this, ReportRelationshipType.AMENDEDWITH, code);
      if ("appendedWith".equals(codeString))
        return new Enumeration<ReportRelationshipType>(this, ReportRelationshipType.APPENDEDWITH, code);
      if ("transformedWith".equals(codeString))
        return new Enumeration<ReportRelationshipType>(this, ReportRelationshipType.TRANSFORMEDWITH, code);
      throw new FHIRException("Unknown ReportRelationshipType code '" + codeString + "'");
    }

    public String toCode(ReportRelationshipType code) {
       if (code == ReportRelationshipType.NULL)
           return null;
       if (code == ReportRelationshipType.REPLACES)
        return "replaces";
      if (code == ReportRelationshipType.AMENDS)
        return "amends";
      if (code == ReportRelationshipType.APPENDS)
        return "appends";
      if (code == ReportRelationshipType.TRANSFORMS)
        return "transforms";
      if (code == ReportRelationshipType.REPLACEDWITH)
        return "replacedWith";
      if (code == ReportRelationshipType.AMENDEDWITH)
        return "amendedWith";
      if (code == ReportRelationshipType.APPENDEDWITH)
        return "appendedWith";
      if (code == ReportRelationshipType.TRANSFORMEDWITH)
        return "transformedWith";
      return "?";
   }

    public String toSystem(ReportRelationshipType code) {
      return code.getSystem();
    }
  }

  @Block()
  public static class EvidenceReportSubjectComponent extends BackboneElement implements IBaseBackboneElement {
    /**
     * Characteristic.
     */
    @Child(name = "characteristic", type = {}, order = 1, min = 0, max = Child.MAX_UNLIMITED, modifier = false, summary = false)
    @Description(shortDefinition = "Characteristic", formalDefinition = "Characteristic.")
    protected List<EvidenceReportSubjectCharacteristicComponent> characteristic;

    /**
     * Used for general notes and annotations not coded elsewhere.
     */
    @Child(name = "note", type = {
        Annotation.class }, order = 2, min = 0, max = Child.MAX_UNLIMITED, modifier = false, summary = false)
    @Description(shortDefinition = "Footnotes and/or explanatory notes", formalDefinition = "Used for general notes and annotations not coded elsewhere.")
    protected List<Annotation> note;

    private static final long serialVersionUID = -734040873L;

    /**
     * Constructor
     */
    public EvidenceReportSubjectComponent() {
      super();
    }

    /**
     * @return {@link #characteristic} (Characteristic.)
     */
    public List<EvidenceReportSubjectCharacteristicComponent> getCharacteristic() {
      if (this.characteristic == null)
        this.characteristic = new ArrayList<EvidenceReportSubjectCharacteristicComponent>();
      return this.characteristic;
    }

    /**
     * @return Returns a reference to <code>this</code> for easy method chaining
     */
    public EvidenceReportSubjectComponent setCharacteristic(
        List<EvidenceReportSubjectCharacteristicComponent> theCharacteristic) {
      this.characteristic = theCharacteristic;
      return this;
    }

    public boolean hasCharacteristic() {
      if (this.characteristic == null)
        return false;
      for (EvidenceReportSubjectCharacteristicComponent item : this.characteristic)
        if (!item.isEmpty())
          return true;
      return false;
    }

    public EvidenceReportSubjectCharacteristicComponent addCharacteristic() { // 3
      EvidenceReportSubjectCharacteristicComponent t = new EvidenceReportSubjectCharacteristicComponent();
      if (this.characteristic == null)
        this.characteristic = new ArrayList<EvidenceReportSubjectCharacteristicComponent>();
      this.characteristic.add(t);
      return t;
    }

    public EvidenceReportSubjectComponent addCharacteristic(EvidenceReportSubjectCharacteristicComponent t) { // 3
      if (t == null)
        return this;
      if (this.characteristic == null)
        this.characteristic = new ArrayList<EvidenceReportSubjectCharacteristicComponent>();
      this.characteristic.add(t);
      return this;
    }

    /**
     * @return The first repetition of repeating field {@link #characteristic},
     *         creating it if it does not already exist {3}
     */
    public EvidenceReportSubjectCharacteristicComponent getCharacteristicFirstRep() {
      if (getCharacteristic().isEmpty()) {
        addCharacteristic();
      }
      return getCharacteristic().get(0);
    }

    /**
     * @return {@link #note} (Used for general notes and annotations not coded
     *         elsewhere.)
     */
    public List<Annotation> getNote() {
      if (this.note == null)
        this.note = new ArrayList<Annotation>();
      return this.note;
    }

    /**
     * @return Returns a reference to <code>this</code> for easy method chaining
     */
    public EvidenceReportSubjectComponent setNote(List<Annotation> theNote) {
      this.note = theNote;
      return this;
    }

    public boolean hasNote() {
      if (this.note == null)
        return false;
      for (Annotation item : this.note)
        if (!item.isEmpty())
          return true;
      return false;
    }

    public Annotation addNote() { // 3
      Annotation t = new Annotation();
      if (this.note == null)
        this.note = new ArrayList<Annotation>();
      this.note.add(t);
      return t;
    }

    public EvidenceReportSubjectComponent addNote(Annotation t) { // 3
      if (t == null)
        return this;
      if (this.note == null)
        this.note = new ArrayList<Annotation>();
      this.note.add(t);
      return this;
    }

    /**
     * @return The first repetition of repeating field {@link #note}, creating it if
     *         it does not already exist {3}
     */
    public Annotation getNoteFirstRep() {
      if (getNote().isEmpty()) {
        addNote();
      }
      return getNote().get(0);
    }

    protected void listChildren(List<Property> children) {
      super.listChildren(children);
      children
          .add(new Property("characteristic", "", "Characteristic.", 0, java.lang.Integer.MAX_VALUE, characteristic));
      children.add(new Property("note", "Annotation", "Used for general notes and annotations not coded elsewhere.", 0,
          java.lang.Integer.MAX_VALUE, note));
    }

    @Override
    public Property getNamedProperty(int _hash, String _name, boolean _checkValid) throws FHIRException {
      switch (_hash) {
      case 366313883:
        /* characteristic */ return new Property("characteristic", "", "Characteristic.", 0,
            java.lang.Integer.MAX_VALUE, characteristic);
      case 3387378:
        /* note */ return new Property("note", "Annotation",
            "Used for general notes and annotations not coded elsewhere.", 0, java.lang.Integer.MAX_VALUE, note);
      default:
        return super.getNamedProperty(_hash, _name, _checkValid);
      }

    }

    @Override
    public Base[] getProperty(int hash, String name, boolean checkValid) throws FHIRException {
      switch (hash) {
      case 366313883:
        /* characteristic */ return this.characteristic == null ? new Base[0]
            : this.characteristic.toArray(new Base[this.characteristic.size()]); // EvidenceReportSubjectCharacteristicComponent
      case 3387378:
        /* note */ return this.note == null ? new Base[0] : this.note.toArray(new Base[this.note.size()]); // Annotation
      default:
        return super.getProperty(hash, name, checkValid);
      }

    }

    @Override
    public Base setProperty(int hash, String name, Base value) throws FHIRException {
      switch (hash) {
      case 366313883: // characteristic
        this.getCharacteristic().add((EvidenceReportSubjectCharacteristicComponent) value); // EvidenceReportSubjectCharacteristicComponent
        return value;
      case 3387378: // note
        this.getNote().add(TypeConvertor.castToAnnotation(value)); // Annotation
        return value;
      default:
        return super.setProperty(hash, name, value);
      }

    }

    @Override
    public Base setProperty(String name, Base value) throws FHIRException {
      if (name.equals("characteristic")) {
        this.getCharacteristic().add((EvidenceReportSubjectCharacteristicComponent) value);
      } else if (name.equals("note")) {
        this.getNote().add(TypeConvertor.castToAnnotation(value));
      } else
        return super.setProperty(name, value);
      return value;
    }

  @Override
  public void removeChild(String name, Base value) throws FHIRException {
      if (name.equals("characteristic")) {
        this.getCharacteristic().remove((EvidenceReportSubjectCharacteristicComponent) value);
      } else if (name.equals("note")) {
        this.getNote().remove(value);
      } else
        super.removeChild(name, value);
      
    }

    @Override
    public Base makeProperty(int hash, String name) throws FHIRException {
      switch (hash) {
      case 366313883:
        return addCharacteristic();
      case 3387378:
        return addNote();
      default:
        return super.makeProperty(hash, name);
      }

    }

    @Override
    public String[] getTypesForProperty(int hash, String name) throws FHIRException {
      switch (hash) {
      case 366313883:
        /* characteristic */ return new String[] {};
      case 3387378:
        /* note */ return new String[] { "Annotation" };
      default:
        return super.getTypesForProperty(hash, name);
      }

    }

    @Override
    public Base addChild(String name) throws FHIRException {
      if (name.equals("characteristic")) {
        return addCharacteristic();
      } else if (name.equals("note")) {
        return addNote();
      } else
        return super.addChild(name);
    }

    public EvidenceReportSubjectComponent copy() {
      EvidenceReportSubjectComponent dst = new EvidenceReportSubjectComponent();
      copyValues(dst);
      return dst;
    }

    public void copyValues(EvidenceReportSubjectComponent dst) {
      super.copyValues(dst);
      if (characteristic != null) {
        dst.characteristic = new ArrayList<EvidenceReportSubjectCharacteristicComponent>();
        for (EvidenceReportSubjectCharacteristicComponent i : characteristic)
          dst.characteristic.add(i.copy());
      }
      ;
      if (note != null) {
        dst.note = new ArrayList<Annotation>();
        for (Annotation i : note)
          dst.note.add(i.copy());
      }
      ;
    }

    @Override
    public boolean equalsDeep(Base other_) {
      if (!super.equalsDeep(other_))
        return false;
      if (!(other_ instanceof EvidenceReportSubjectComponent))
        return false;
      EvidenceReportSubjectComponent o = (EvidenceReportSubjectComponent) other_;
      return compareDeep(characteristic, o.characteristic, true) && compareDeep(note, o.note, true);
    }

    @Override
    public boolean equalsShallow(Base other_) {
      if (!super.equalsShallow(other_))
        return false;
      if (!(other_ instanceof EvidenceReportSubjectComponent))
        return false;
      EvidenceReportSubjectComponent o = (EvidenceReportSubjectComponent) other_;
      return true;
    }

    public boolean isEmpty() {
      return super.isEmpty() && ca.uhn.fhir.util.ElementUtil.isEmpty(characteristic, note);
    }

    public String fhirType() {
      return "EvidenceReport.subject";

    }

  }

  @Block()
  public static class EvidenceReportSubjectCharacteristicComponent extends BackboneElement
      implements IBaseBackboneElement {
    /**
     * Characteristic code.
     */
    @Child(name = "code", type = {
        CodeableConcept.class }, order = 1, min = 1, max = 1, modifier = false, summary = false)
    @Description(shortDefinition = "Characteristic code", formalDefinition = "Characteristic code.")
    @ca.uhn.fhir.model.api.annotation.Binding(valueSet = "http://hl7.org/fhir/ValueSet/focus-characteristic-code")
    protected CodeableConcept code;

    /**
     * Characteristic value.
     */
    @Child(name = "value", type = { Reference.class, CodeableConcept.class, BooleanType.class, Quantity.class,
        Range.class }, order = 2, min = 1, max = 1, modifier = false, summary = false)
    @Description(shortDefinition = "Characteristic value", formalDefinition = "Characteristic value.")
    protected DataType value;

    /**
     * Is used to express not the characteristic.
     */
    @Child(name = "exclude", type = {
        BooleanType.class }, order = 3, min = 0, max = 1, modifier = false, summary = false)
    @Description(shortDefinition = "Is used to express not the characteristic", formalDefinition = "Is used to express not the characteristic.")
    protected BooleanType exclude;

    /**
     * Timeframe for the characteristic.
     */
    @Child(name = "period", type = { Period.class }, order = 4, min = 0, max = 1, modifier = false, summary = false)
    @Description(shortDefinition = "Timeframe for the characteristic", formalDefinition = "Timeframe for the characteristic.")
    protected Period period;

    private static final long serialVersionUID = 279867823L;

    /**
     * Constructor
     */
    public EvidenceReportSubjectCharacteristicComponent() {
      super();
    }

    /**
     * Constructor
     */
    public EvidenceReportSubjectCharacteristicComponent(CodeableConcept code, DataType value) {
      super();
      this.setCode(code);
      this.setValue(value);
    }

    /**
     * @return {@link #code} (Characteristic code.)
     */
    public CodeableConcept getCode() {
      if (this.code == null)
        if (Configuration.errorOnAutoCreate())
          throw new Error("Attempt to auto-create EvidenceReportSubjectCharacteristicComponent.code");
        else if (Configuration.doAutoCreate())
          this.code = new CodeableConcept(); // cc
      return this.code;
    }

    public boolean hasCode() {
      return this.code != null && !this.code.isEmpty();
    }

    /**
     * @param value {@link #code} (Characteristic code.)
     */
    public EvidenceReportSubjectCharacteristicComponent setCode(CodeableConcept value) {
      this.code = value;
      return this;
    }

    /**
     * @return {@link #value} (Characteristic value.)
     */
    public DataType getValue() {
      return this.value;
    }

    /**
     * @return {@link #value} (Characteristic value.)
     */
    public Reference getValueReference() throws FHIRException {
      if (this.value == null)
        this.value = new Reference();
      if (!(this.value instanceof Reference))
        throw new FHIRException("Type mismatch: the type Reference was expected, but " + this.value.getClass().getName()
            + " was encountered");
      return (Reference) this.value;
    }

    public boolean hasValueReference() {
        return this.value instanceof Reference;
    }

    /**
     * @return {@link #value} (Characteristic value.)
     */
    public CodeableConcept getValueCodeableConcept() throws FHIRException {
      if (this.value == null)
        this.value = new CodeableConcept();
      if (!(this.value instanceof CodeableConcept))
        throw new FHIRException("Type mismatch: the type CodeableConcept was expected, but "
            + this.value.getClass().getName() + " was encountered");
      return (CodeableConcept) this.value;
    }

    public boolean hasValueCodeableConcept() {
        return this.value instanceof CodeableConcept;
    }

    /**
     * @return {@link #value} (Characteristic value.)
     */
    public BooleanType getValueBooleanType() throws FHIRException {
      if (this.value == null)
        this.value = new BooleanType();
      if (!(this.value instanceof BooleanType))
        throw new FHIRException("Type mismatch: the type BooleanType was expected, but "
            + this.value.getClass().getName() + " was encountered");
      return (BooleanType) this.value;
    }

    public boolean hasValueBooleanType() {
        return this.value instanceof BooleanType;
    }

    /**
     * @return {@link #value} (Characteristic value.)
     */
    public Quantity getValueQuantity() throws FHIRException {
      if (this.value == null)
        this.value = new Quantity();
      if (!(this.value instanceof Quantity))
        throw new FHIRException("Type mismatch: the type Quantity was expected, but " + this.value.getClass().getName()
            + " was encountered");
      return (Quantity) this.value;
    }

    public boolean hasValueQuantity() {
        return this.value instanceof Quantity;
    }

    /**
     * @return {@link #value} (Characteristic value.)
     */
    public Range getValueRange() throws FHIRException {
      if (this.value == null)
        this.value = new Range();
      if (!(this.value instanceof Range))
        throw new FHIRException(
            "Type mismatch: the type Range was expected, but " + this.value.getClass().getName() + " was encountered");
      return (Range) this.value;
    }

    public boolean hasValueRange() {
        return this.value instanceof Range;
    }

    public boolean hasValue() {
      return this.value != null && !this.value.isEmpty();
    }

    /**
     * @param value {@link #value} (Characteristic value.)
     */
    public EvidenceReportSubjectCharacteristicComponent setValue(DataType value) {
      if (value != null && !(value instanceof Reference || value instanceof CodeableConcept
          || value instanceof BooleanType || value instanceof Quantity || value instanceof Range))
        throw new Error("Not the right type for EvidenceReport.subject.characteristic.value[x]: " + value.fhirType());
      this.value = value;
      return this;
    }

    /**
     * @return {@link #exclude} (Is used to express not the characteristic.). This
     *         is the underlying object with id, value and extensions. The accessor
     *         "getExclude" gives direct access to the value
     */
    public BooleanType getExcludeElement() {
      if (this.exclude == null)
        if (Configuration.errorOnAutoCreate())
          throw new Error("Attempt to auto-create EvidenceReportSubjectCharacteristicComponent.exclude");
        else if (Configuration.doAutoCreate())
          this.exclude = new BooleanType(); // bb
      return this.exclude;
    }

    public boolean hasExcludeElement() {
      return this.exclude != null && !this.exclude.isEmpty();
    }

    public boolean hasExclude() {
      return this.exclude != null && !this.exclude.isEmpty();
    }

    /**
     * @param value {@link #exclude} (Is used to express not the characteristic.).
     *              This is the underlying object with id, value and extensions. The
     *              accessor "getExclude" gives direct access to the value
     */
    public EvidenceReportSubjectCharacteristicComponent setExcludeElement(BooleanType value) {
      this.exclude = value;
      return this;
    }

    /**
     * @return Is used to express not the characteristic.
     */
    public boolean getExclude() {
      return this.exclude == null || this.exclude.isEmpty() ? false : this.exclude.getValue();
    }

    /**
     * @param value Is used to express not the characteristic.
     */
    public EvidenceReportSubjectCharacteristicComponent setExclude(boolean value) {
      if (this.exclude == null)
        this.exclude = new BooleanType();
      this.exclude.setValue(value);
      return this;
    }

    /**
     * @return {@link #period} (Timeframe for the characteristic.)
     */
    public Period getPeriod() {
      if (this.period == null)
        if (Configuration.errorOnAutoCreate())
          throw new Error("Attempt to auto-create EvidenceReportSubjectCharacteristicComponent.period");
        else if (Configuration.doAutoCreate())
          this.period = new Period(); // cc
      return this.period;
    }

    public boolean hasPeriod() {
      return this.period != null && !this.period.isEmpty();
    }

    /**
     * @param value {@link #period} (Timeframe for the characteristic.)
     */
    public EvidenceReportSubjectCharacteristicComponent setPeriod(Period value) {
      this.period = value;
      return this;
    }

    protected void listChildren(List<Property> children) {
      super.listChildren(children);
      children.add(new Property("code", "CodeableConcept", "Characteristic code.", 0, 1, code));
      children.add(new Property("value[x]", "Reference(Any)|CodeableConcept|boolean|Quantity|Range",
          "Characteristic value.", 0, 1, value));
      children.add(new Property("exclude", "boolean", "Is used to express not the characteristic.", 0, 1, exclude));
      children.add(new Property("period", "Period", "Timeframe for the characteristic.", 0, 1, period));
    }

    @Override
    public Property getNamedProperty(int _hash, String _name, boolean _checkValid) throws FHIRException {
      switch (_hash) {
      case 3059181:
        /* code */ return new Property("code", "CodeableConcept", "Characteristic code.", 0, 1, code);
      case -1410166417:
        /* value[x] */ return new Property("value[x]", "Reference(Any)|CodeableConcept|boolean|Quantity|Range",
            "Characteristic value.", 0, 1, value);
      case 111972721:
        /* value */ return new Property("value[x]", "Reference(Any)|CodeableConcept|boolean|Quantity|Range",
            "Characteristic value.", 0, 1, value);
      case 1755241690:
        /* valueReference */ return new Property("value[x]", "Reference(Any)", "Characteristic value.", 0, 1, value);
      case 924902896:
        /* valueCodeableConcept */ return new Property("value[x]", "CodeableConcept", "Characteristic value.", 0, 1,
            value);
      case 733421943:
        /* valueBoolean */ return new Property("value[x]", "boolean", "Characteristic value.", 0, 1, value);
      case -2029823716:
        /* valueQuantity */ return new Property("value[x]", "Quantity", "Characteristic value.", 0, 1, value);
      case 2030761548:
        /* valueRange */ return new Property("value[x]", "Range", "Characteristic value.", 0, 1, value);
      case -1321148966:
        /* exclude */ return new Property("exclude", "boolean", "Is used to express not the characteristic.", 0, 1,
            exclude);
      case -991726143:
        /* period */ return new Property("period", "Period", "Timeframe for the characteristic.", 0, 1, period);
      default:
        return super.getNamedProperty(_hash, _name, _checkValid);
      }

    }

    @Override
    public Base[] getProperty(int hash, String name, boolean checkValid) throws FHIRException {
      switch (hash) {
      case 3059181:
        /* code */ return this.code == null ? new Base[0] : new Base[] { this.code }; // CodeableConcept
      case 111972721:
        /* value */ return this.value == null ? new Base[0] : new Base[] { this.value }; // DataType
      case -1321148966:
        /* exclude */ return this.exclude == null ? new Base[0] : new Base[] { this.exclude }; // BooleanType
      case -991726143:
        /* period */ return this.period == null ? new Base[0] : new Base[] { this.period }; // Period
      default:
        return super.getProperty(hash, name, checkValid);
      }

    }

    @Override
    public Base setProperty(int hash, String name, Base value) throws FHIRException {
      switch (hash) {
      case 3059181: // code
        this.code = TypeConvertor.castToCodeableConcept(value); // CodeableConcept
        return value;
      case 111972721: // value
        this.value = TypeConvertor.castToType(value); // DataType
        return value;
      case -1321148966: // exclude
        this.exclude = TypeConvertor.castToBoolean(value); // BooleanType
        return value;
      case -991726143: // period
        this.period = TypeConvertor.castToPeriod(value); // Period
        return value;
      default:
        return super.setProperty(hash, name, value);
      }

    }

    @Override
    public Base setProperty(String name, Base value) throws FHIRException {
      if (name.equals("code")) {
        this.code = TypeConvertor.castToCodeableConcept(value); // CodeableConcept
      } else if (name.equals("value[x]")) {
        this.value = TypeConvertor.castToType(value); // DataType
      } else if (name.equals("exclude")) {
        this.exclude = TypeConvertor.castToBoolean(value); // BooleanType
      } else if (name.equals("period")) {
        this.period = TypeConvertor.castToPeriod(value); // Period
      } else
        return super.setProperty(name, value);
      return value;
    }

  @Override
  public void removeChild(String name, Base value) throws FHIRException {
      if (name.equals("code")) {
        this.code = null;
      } else if (name.equals("value[x]")) {
        this.value = null;
      } else if (name.equals("exclude")) {
        this.exclude = null;
      } else if (name.equals("period")) {
        this.period = null;
      } else
        super.removeChild(name, value);
      
    }

    @Override
    public Base makeProperty(int hash, String name) throws FHIRException {
      switch (hash) {
      case 3059181:
        return getCode();
      case -1410166417:
        return getValue();
      case 111972721:
        return getValue();
      case -1321148966:
        return getExcludeElement();
      case -991726143:
        return getPeriod();
      default:
        return super.makeProperty(hash, name);
      }

    }

    @Override
    public String[] getTypesForProperty(int hash, String name) throws FHIRException {
      switch (hash) {
      case 3059181:
        /* code */ return new String[] { "CodeableConcept" };
      case 111972721:
        /* value */ return new String[] { "Reference", "CodeableConcept", "boolean", "Quantity", "Range" };
      case -1321148966:
        /* exclude */ return new String[] { "boolean" };
      case -991726143:
        /* period */ return new String[] { "Period" };
      default:
        return super.getTypesForProperty(hash, name);
      }

    }

    @Override
    public Base addChild(String name) throws FHIRException {
      if (name.equals("code")) {
        this.code = new CodeableConcept();
        return this.code;
      } else if (name.equals("valueReference")) {
        this.value = new Reference();
        return this.value;
      } else if (name.equals("valueCodeableConcept")) {
        this.value = new CodeableConcept();
        return this.value;
      } else if (name.equals("valueBoolean")) {
        this.value = new BooleanType();
        return this.value;
      } else if (name.equals("valueQuantity")) {
        this.value = new Quantity();
        return this.value;
      } else if (name.equals("valueRange")) {
        this.value = new Range();
        return this.value;
      } else if (name.equals("exclude")) {
        throw new FHIRException(
            "Cannot call addChild on a singleton property EvidenceReport.subject.characteristic.exclude");
      } else if (name.equals("period")) {
        this.period = new Period();
        return this.period;
      } else
        return super.addChild(name);
    }

    public EvidenceReportSubjectCharacteristicComponent copy() {
      EvidenceReportSubjectCharacteristicComponent dst = new EvidenceReportSubjectCharacteristicComponent();
      copyValues(dst);
      return dst;
    }

    public void copyValues(EvidenceReportSubjectCharacteristicComponent dst) {
      super.copyValues(dst);
      dst.code = code == null ? null : code.copy();
      dst.value = value == null ? null : value.copy();
      dst.exclude = exclude == null ? null : exclude.copy();
      dst.period = period == null ? null : period.copy();
    }

    @Override
    public boolean equalsDeep(Base other_) {
      if (!super.equalsDeep(other_))
        return false;
      if (!(other_ instanceof EvidenceReportSubjectCharacteristicComponent))
        return false;
      EvidenceReportSubjectCharacteristicComponent o = (EvidenceReportSubjectCharacteristicComponent) other_;
      return compareDeep(code, o.code, true) && compareDeep(value, o.value, true)
          && compareDeep(exclude, o.exclude, true) && compareDeep(period, o.period, true);
    }

    @Override
    public boolean equalsShallow(Base other_) {
      if (!super.equalsShallow(other_))
        return false;
      if (!(other_ instanceof EvidenceReportSubjectCharacteristicComponent))
        return false;
      EvidenceReportSubjectCharacteristicComponent o = (EvidenceReportSubjectCharacteristicComponent) other_;
      return compareValues(exclude, o.exclude, true);
    }

    public boolean isEmpty() {
      return super.isEmpty() && ca.uhn.fhir.util.ElementUtil.isEmpty(code, value, exclude, period);
    }

    public String fhirType() {
      return "EvidenceReport.subject.characteristic";

    }

  }

  @Block()
  public static class EvidenceReportRelatesToComponent extends BackboneElement implements IBaseBackboneElement {
    /**
     * The type of relationship that this composition has with anther composition or
     * document.
     */
    @Child(name = "code", type = { CodeType.class }, order = 1, min = 1, max = 1, modifier = false, summary = false)
    @Description(shortDefinition = "replaces | amends | appends | transforms | replacedWith | amendedWith | appendedWith | transformedWith", formalDefinition = "The type of relationship that this composition has with anther composition or document.")
    @ca.uhn.fhir.model.api.annotation.Binding(valueSet = "http://hl7.org/fhir/ValueSet/report-relation-type")
    protected Enumeration<ReportRelationshipType> code;

    /**
     * The target composition/document of this relationship.
     */
    @Child(name = "target", type = { Identifier.class,
        EvidenceReport.class }, order = 2, min = 1, max = 1, modifier = false, summary = false)
    @Description(shortDefinition = "Target of the relationship", formalDefinition = "The target composition/document of this relationship.")
    protected DataType target;

    private static final long serialVersionUID = -1091549831L;

    /**
     * Constructor
     */
    public EvidenceReportRelatesToComponent() {
      super();
    }

    /**
     * Constructor
     */
    public EvidenceReportRelatesToComponent(ReportRelationshipType code, DataType target) {
      super();
      this.setCode(code);
      this.setTarget(target);
    }

    /**
     * @return {@link #code} (The type of relationship that this composition has
     *         with anther composition or document.). This is the underlying object
     *         with id, value and extensions. The accessor "getCode" gives direct
     *         access to the value
     */
    public Enumeration<ReportRelationshipType> getCodeElement() {
      if (this.code == null)
        if (Configuration.errorOnAutoCreate())
          throw new Error("Attempt to auto-create EvidenceReportRelatesToComponent.code");
        else if (Configuration.doAutoCreate())
          this.code = new Enumeration<ReportRelationshipType>(new ReportRelationshipTypeEnumFactory()); // bb
      return this.code;
    }

    public boolean hasCodeElement() {
      return this.code != null && !this.code.isEmpty();
    }

    public boolean hasCode() {
      return this.code != null && !this.code.isEmpty();
    }

    /**
     * @param value {@link #code} (The type of relationship that this composition
     *              has with anther composition or document.). This is the
     *              underlying object with id, value and extensions. The accessor
     *              "getCode" gives direct access to the value
     */
    public EvidenceReportRelatesToComponent setCodeElement(Enumeration<ReportRelationshipType> value) {
      this.code = value;
      return this;
    }

    /**
     * @return The type of relationship that this composition has with anther
     *         composition or document.
     */
    public ReportRelationshipType getCode() {
      return this.code == null ? null : this.code.getValue();
    }

    /**
     * @param value The type of relationship that this composition has with anther
     *              composition or document.
     */
    public EvidenceReportRelatesToComponent setCode(ReportRelationshipType value) {
      if (this.code == null)
        this.code = new Enumeration<ReportRelationshipType>(new ReportRelationshipTypeEnumFactory());
      this.code.setValue(value);
      return this;
    }

    /**
     * @return {@link #target} (The target composition/document of this
     *         relationship.)
     */
    public DataType getTarget() {
      return this.target;
    }

    /**
     * @return {@link #target} (The target composition/document of this
     *         relationship.)
     */
    public Identifier getTargetIdentifier() throws FHIRException {
      if (this.target == null)
        this.target = new Identifier();
      if (!(this.target instanceof Identifier))
        throw new FHIRException("Type mismatch: the type Identifier was expected, but "
            + this.target.getClass().getName() + " was encountered");
      return (Identifier) this.target;
    }

    public boolean hasTargetIdentifier() {
        return this.target instanceof Identifier;
    }

    /**
     * @return {@link #target} (The target composition/document of this
     *         relationship.)
     */
    public Reference getTargetReference() throws FHIRException {
      if (this.target == null)
        this.target = new Reference();
      if (!(this.target instanceof Reference))
        throw new FHIRException("Type mismatch: the type Reference was expected, but "
            + this.target.getClass().getName() + " was encountered");
      return (Reference) this.target;
    }

    public boolean hasTargetReference() {
        return this.target instanceof Reference;
    }

    public boolean hasTarget() {
      return this.target != null && !this.target.isEmpty();
    }

    /**
     * @param value {@link #target} (The target composition/document of this
     *              relationship.)
     */
    public EvidenceReportRelatesToComponent setTarget(DataType value) {
      if (value != null && !(value instanceof Identifier || value instanceof Reference))
        throw new Error("Not the right type for EvidenceReport.relatesTo.target[x]: " + value.fhirType());
      this.target = value;
      return this;
    }

    protected void listChildren(List<Property> children) {
      super.listChildren(children);
      children.add(new Property("code", "code",
          "The type of relationship that this composition has with anther composition or document.", 0, 1, code));
      children.add(new Property("target[x]", "Identifier|Reference(EvidenceReport)",
          "The target composition/document of this relationship.", 0, 1, target));
    }

    @Override
    public Property getNamedProperty(int _hash, String _name, boolean _checkValid) throws FHIRException {
      switch (_hash) {
      case 3059181:
        /* code */ return new Property("code", "code",
            "The type of relationship that this composition has with anther composition or document.", 0, 1, code);
      case -815579825:
        /* target[x] */ return new Property("target[x]", "Identifier|Reference(EvidenceReport)",
            "The target composition/document of this relationship.", 0, 1, target);
      case -880905839:
        /* target */ return new Property("target[x]", "Identifier|Reference(EvidenceReport)",
            "The target composition/document of this relationship.", 0, 1, target);
      case 1690892570:
        /* targetIdentifier */ return new Property("target[x]", "Identifier",
            "The target composition/document of this relationship.", 0, 1, target);
      case 1259806906:
        /* targetReference */ return new Property("target[x]", "Reference(EvidenceReport)",
            "The target composition/document of this relationship.", 0, 1, target);
      default:
        return super.getNamedProperty(_hash, _name, _checkValid);
      }

    }

    @Override
    public Base[] getProperty(int hash, String name, boolean checkValid) throws FHIRException {
      switch (hash) {
      case 3059181:
        /* code */ return this.code == null ? new Base[0] : new Base[] { this.code }; // Enumeration<ReportRelationshipType>
      case -880905839:
        /* target */ return this.target == null ? new Base[0] : new Base[] { this.target }; // DataType
      default:
        return super.getProperty(hash, name, checkValid);
      }

    }

    @Override
    public Base setProperty(int hash, String name, Base value) throws FHIRException {
      switch (hash) {
      case 3059181: // code
        value = new ReportRelationshipTypeEnumFactory().fromType(TypeConvertor.castToCode(value));
        this.code = (Enumeration) value; // Enumeration<ReportRelationshipType>
        return value;
      case -880905839: // target
        this.target = TypeConvertor.castToType(value); // DataType
        return value;
      default:
        return super.setProperty(hash, name, value);
      }

    }

    @Override
    public Base setProperty(String name, Base value) throws FHIRException {
      if (name.equals("code")) {
        value = new ReportRelationshipTypeEnumFactory().fromType(TypeConvertor.castToCode(value));
        this.code = (Enumeration) value; // Enumeration<ReportRelationshipType>
      } else if (name.equals("target[x]")) {
        this.target = TypeConvertor.castToType(value); // DataType
      } else
        return super.setProperty(name, value);
      return value;
    }

  @Override
  public void removeChild(String name, Base value) throws FHIRException {
      if (name.equals("code")) {
        this.code = null;
      } else if (name.equals("target[x]")) {
        this.target = null;
      } else
        super.removeChild(name, value);
      
    }

    @Override
    public Base makeProperty(int hash, String name) throws FHIRException {
      switch (hash) {
      case 3059181:
        return getCodeElement();
      case -815579825:
        return getTarget();
      case -880905839:
        return getTarget();
      default:
        return super.makeProperty(hash, name);
      }

    }

    @Override
    public String[] getTypesForProperty(int hash, String name) throws FHIRException {
      switch (hash) {
      case 3059181:
        /* code */ return new String[] { "code" };
      case -880905839:
        /* target */ return new String[] { "Identifier", "Reference" };
      default:
        return super.getTypesForProperty(hash, name);
      }

    }

    @Override
    public Base addChild(String name) throws FHIRException {
      if (name.equals("code")) {
        throw new FHIRException("Cannot call addChild on a singleton property EvidenceReport.relatesTo.code");
      } else if (name.equals("targetIdentifier")) {
        this.target = new Identifier();
        return this.target;
      } else if (name.equals("targetReference")) {
        this.target = new Reference();
        return this.target;
      } else
        return super.addChild(name);
    }

    public EvidenceReportRelatesToComponent copy() {
      EvidenceReportRelatesToComponent dst = new EvidenceReportRelatesToComponent();
      copyValues(dst);
      return dst;
    }

    public void copyValues(EvidenceReportRelatesToComponent dst) {
      super.copyValues(dst);
      dst.code = code == null ? null : code.copy();
      dst.target = target == null ? null : target.copy();
    }

    @Override
    public boolean equalsDeep(Base other_) {
      if (!super.equalsDeep(other_))
        return false;
      if (!(other_ instanceof EvidenceReportRelatesToComponent))
        return false;
      EvidenceReportRelatesToComponent o = (EvidenceReportRelatesToComponent) other_;
      return compareDeep(code, o.code, true) && compareDeep(target, o.target, true);
    }

    @Override
    public boolean equalsShallow(Base other_) {
      if (!super.equalsShallow(other_))
        return false;
      if (!(other_ instanceof EvidenceReportRelatesToComponent))
        return false;
      EvidenceReportRelatesToComponent o = (EvidenceReportRelatesToComponent) other_;
      return compareValues(code, o.code, true);
    }

    public boolean isEmpty() {
      return super.isEmpty() && ca.uhn.fhir.util.ElementUtil.isEmpty(code, target);
    }

    public String fhirType() {
      return "EvidenceReport.relatesTo";

    }

  }

  @Block()
  public static class SectionComponent extends BackboneElement implements IBaseBackboneElement {
    /**
     * The label for this particular section. This will be part of the rendered
     * content for the document, and is often used to build a table of contents.
     */
    @Child(name = "title", type = { StringType.class }, order = 1, min = 0, max = 1, modifier = false, summary = false)
    @Description(shortDefinition = "Label for section (e.g. for ToC)", formalDefinition = "The label for this particular section.  This will be part of the rendered content for the document, and is often used to build a table of contents.")
    protected StringType title;

    /**
     * A code identifying the kind of content contained within the section. This
     * should be consistent with the section title.
     */
    @Child(name = "focus", type = {
        CodeableConcept.class }, order = 2, min = 0, max = 1, modifier = false, summary = false)
    @Description(shortDefinition = "Classification of section (recommended)", formalDefinition = "A code identifying the kind of content contained within the section. This should be consistent with the section title.")
    @ca.uhn.fhir.model.api.annotation.Binding(valueSet = "http://hl7.org/fhir/ValueSet/evidence-report-section")
    protected CodeableConcept focus;

    /**
     * A definitional Resource identifying the kind of content contained within the
     * section. This should be consistent with the section title.
     */
    @Child(name = "focusReference", type = {
        Reference.class }, order = 3, min = 0, max = 1, modifier = false, summary = false)
    @Description(shortDefinition = "Classification of section by Resource", formalDefinition = "A definitional Resource identifying the kind of content contained within the section. This should be consistent with the section title.")
    protected Reference focusReference;

    /**
     * Identifies who is responsible for the information in this section, not
     * necessarily who typed it in.
     */
    @Child(name = "author", type = { Person.class, Device.class, Group.class,
        Organization.class }, order = 4, min = 0, max = Child.MAX_UNLIMITED, modifier = false, summary = false)
    @Description(shortDefinition = "Who and/or what authored the section", formalDefinition = "Identifies who is responsible for the information in this section, not necessarily who typed it in.")
    protected List<Reference> author;

    /**
     * A human-readable narrative that contains the attested content of the section,
     * used to represent the content of the resource to a human. The narrative need
     * not encode all the structured data, but is peferred to contain sufficient
     * detail to make it acceptable for a human to just read the narrative.
     */
    @Child(name = "text", type = { Narrative.class }, order = 5, min = 0, max = 1, modifier = false, summary = false)
    @Description(shortDefinition = "Text summary of the section, for human interpretation", formalDefinition = "A human-readable narrative that contains the attested content of the section, used to represent the content of the resource to a human. The narrative need not encode all the structured data, but is peferred to contain sufficient detail to make it acceptable for a human to just read the narrative.")
    protected Narrative text;

    /**
     * How the entry list was prepared - whether it is a working list that is
     * suitable for being maintained on an ongoing basis, or if it represents a
     * snapshot of a list of items from another source, or whether it is a prepared
     * list where items may be marked as added, modified or deleted.
     */
    @Child(name = "mode", type = { CodeType.class }, order = 6, min = 0, max = 1, modifier = false, summary = false)
    @Description(shortDefinition = "working | snapshot | changes", formalDefinition = "How the entry list was prepared - whether it is a working list that is suitable for being maintained on an ongoing basis, or if it represents a snapshot of a list of items from another source, or whether it is a prepared list where items may be marked as added, modified or deleted.")
    @ca.uhn.fhir.model.api.annotation.Binding(valueSet = "http://hl7.org/fhir/ValueSet/list-mode")
    protected Enumeration<ListMode> mode;

    /**
     * Specifies the order applied to the items in the section entries.
     */
    @Child(name = "orderedBy", type = {
        CodeableConcept.class }, order = 7, min = 0, max = 1, modifier = false, summary = false)
    @Description(shortDefinition = "Order of section entries", formalDefinition = "Specifies the order applied to the items in the section entries.")
    @ca.uhn.fhir.model.api.annotation.Binding(valueSet = "http://hl7.org/fhir/ValueSet/list-order")
    protected CodeableConcept orderedBy;

    /**
     * Specifies any type of classification of the evidence report.
     */
    @Child(name = "entryClassifier", type = {
        CodeableConcept.class }, order = 8, min = 0, max = Child.MAX_UNLIMITED, modifier = false, summary = false)
    @Description(shortDefinition = "Extensible classifiers as content", formalDefinition = "Specifies any type of classification of the evidence report.")
    @ca.uhn.fhir.model.api.annotation.Binding(valueSet = "http://hl7.org/fhir/ValueSet/evidence-classifier-code")
    protected List<CodeableConcept> entryClassifier;

    /**
     * A reference to the actual resource from which the narrative in the section is
     * derived.
     */
    @Child(name = "entryReference", type = {
        Reference.class }, order = 9, min = 0, max = Child.MAX_UNLIMITED, modifier = false, summary = false)
    @Description(shortDefinition = "Reference to resources as content", formalDefinition = "A reference to the actual resource from which the narrative in the section is derived.")
    protected List<Reference> entryReference;

    /**
     * Quantity as content.
     */
    @Child(name = "entryQuantity", type = {
        Quantity.class }, order = 10, min = 0, max = Child.MAX_UNLIMITED, modifier = false, summary = false)
    @Description(shortDefinition = "Quantity as content", formalDefinition = "Quantity as content.")
    protected List<Quantity> entryQuantity;

    /**
     * If the section is empty, why the list is empty. An empty section typically
     * has some text explaining the empty reason.
     */
    @Child(name = "emptyReason", type = {
        CodeableConcept.class }, order = 11, min = 0, max = 1, modifier = false, summary = false)
    @Description(shortDefinition = "Why the section is empty", formalDefinition = "If the section is empty, why the list is empty. An empty section typically has some text explaining the empty reason.")
    @ca.uhn.fhir.model.api.annotation.Binding(valueSet = "http://hl7.org/fhir/ValueSet/list-empty-reason")
    protected CodeableConcept emptyReason;

    /**
     * A nested sub-section within this section.
     */
    @Child(name = "section", type = {
        SectionComponent.class }, order = 12, min = 0, max = Child.MAX_UNLIMITED, modifier = false, summary = false)
    @Description(shortDefinition = "Nested Section", formalDefinition = "A nested sub-section within this section.")
    protected List<SectionComponent> section;

    private static final long serialVersionUID = -324854168L;

    /**
     * Constructor
     */
    public SectionComponent() {
      super();
    }

    /**
     * @return {@link #title} (The label for this particular section. This will be
     *         part of the rendered content for the document, and is often used to
     *         build a table of contents.). This is the underlying object with id,
     *         value and extensions. The accessor "getTitle" gives direct access to
     *         the value
     */
    public StringType getTitleElement() {
      if (this.title == null)
        if (Configuration.errorOnAutoCreate())
          throw new Error("Attempt to auto-create SectionComponent.title");
        else if (Configuration.doAutoCreate())
          this.title = new StringType(); // bb
      return this.title;
    }

    public boolean hasTitleElement() {
      return this.title != null && !this.title.isEmpty();
    }

    public boolean hasTitle() {
      return this.title != null && !this.title.isEmpty();
    }

    /**
     * @param value {@link #title} (The label for this particular section. This will
     *              be part of the rendered content for the document, and is often
     *              used to build a table of contents.). This is the underlying
     *              object with id, value and extensions. The accessor "getTitle"
     *              gives direct access to the value
     */
    public SectionComponent setTitleElement(StringType value) {
      this.title = value;
      return this;
    }

    /**
     * @return The label for this particular section. This will be part of the
     *         rendered content for the document, and is often used to build a table
     *         of contents.
     */
    public String getTitle() {
      return this.title == null ? null : this.title.getValue();
    }

    /**
     * @param value The label for this particular section. This will be part of the
     *              rendered content for the document, and is often used to build a
     *              table of contents.
     */
    public SectionComponent setTitle(String value) {
      if (Utilities.noString(value))
        this.title = null;
      else {
        if (this.title == null)
          this.title = new StringType();
        this.title.setValue(value);
      }
      return this;
    }

    /**
     * @return {@link #focus} (A code identifying the kind of content contained
     *         within the section. This should be consistent with the section
     *         title.)
     */
    public CodeableConcept getFocus() {
      if (this.focus == null)
        if (Configuration.errorOnAutoCreate())
          throw new Error("Attempt to auto-create SectionComponent.focus");
        else if (Configuration.doAutoCreate())
          this.focus = new CodeableConcept(); // cc
      return this.focus;
    }

    public boolean hasFocus() {
      return this.focus != null && !this.focus.isEmpty();
    }

    /**
     * @param value {@link #focus} (A code identifying the kind of content contained
     *              within the section. This should be consistent with the section
     *              title.)
     */
    public SectionComponent setFocus(CodeableConcept value) {
      this.focus = value;
      return this;
    }

    /**
     * @return {@link #focusReference} (A definitional Resource identifying the kind
     *         of content contained within the section. This should be consistent
     *         with the section title.)
     */
    public Reference getFocusReference() {
      if (this.focusReference == null)
        if (Configuration.errorOnAutoCreate())
          throw new Error("Attempt to auto-create SectionComponent.focusReference");
        else if (Configuration.doAutoCreate())
          this.focusReference = new Reference(); // cc
      return this.focusReference;
    }

    public boolean hasFocusReference() {
      return this.focusReference != null && !this.focusReference.isEmpty();
    }

    /**
     * @param value {@link #focusReference} (A definitional Resource identifying the
     *              kind of content contained within the section. This should be
     *              consistent with the section title.)
     */
    public SectionComponent setFocusReference(Reference value) {
      this.focusReference = value;
      return this;
    }

    /**
     * @return {@link #author} (Identifies who is responsible for the information in
     *         this section, not necessarily who typed it in.)
     */
    public List<Reference> getAuthor() {
      if (this.author == null)
        this.author = new ArrayList<Reference>();
      return this.author;
    }

    /**
     * @return Returns a reference to <code>this</code> for easy method chaining
     */
    public SectionComponent setAuthor(List<Reference> theAuthor) {
      this.author = theAuthor;
      return this;
    }

    public boolean hasAuthor() {
      if (this.author == null)
        return false;
      for (Reference item : this.author)
        if (!item.isEmpty())
          return true;
      return false;
    }

    public Reference addAuthor() { // 3
      Reference t = new Reference();
      if (this.author == null)
        this.author = new ArrayList<Reference>();
      this.author.add(t);
      return t;
    }

    public SectionComponent addAuthor(Reference t) { // 3
      if (t == null)
        return this;
      if (this.author == null)
        this.author = new ArrayList<Reference>();
      this.author.add(t);
      return this;
    }

    /**
     * @return The first repetition of repeating field {@link #author}, creating it
     *         if it does not already exist {3}
     */
    public Reference getAuthorFirstRep() {
      if (getAuthor().isEmpty()) {
        addAuthor();
      }
      return getAuthor().get(0);
    }

    /**
     * @return {@link #text} (A human-readable narrative that contains the attested
     *         content of the section, used to represent the content of the resource
     *         to a human. The narrative need not encode all the structured data,
     *         but is peferred to contain sufficient detail to make it acceptable
     *         for a human to just read the narrative.)
     */
    public Narrative getText() {
      if (this.text == null)
        if (Configuration.errorOnAutoCreate())
          throw new Error("Attempt to auto-create SectionComponent.text");
        else if (Configuration.doAutoCreate())
          this.text = new Narrative(); // cc
      return this.text;
    }

    public boolean hasText() {
      return this.text != null && !this.text.isEmpty();
    }

    /**
     * @param value {@link #text} (A human-readable narrative that contains the
     *              attested content of the section, used to represent the content
     *              of the resource to a human. The narrative need not encode all
     *              the structured data, but is peferred to contain sufficient
     *              detail to make it acceptable for a human to just read the
     *              narrative.)
     */
    public SectionComponent setText(Narrative value) {
      this.text = value;
      return this;
    }

    /**
     * @return {@link #mode} (How the entry list was prepared - whether it is a
     *         working list that is suitable for being maintained on an ongoing
     *         basis, or if it represents a snapshot of a list of items from another
     *         source, or whether it is a prepared list where items may be marked as
     *         added, modified or deleted.). This is the underlying object with id,
     *         value and extensions. The accessor "getMode" gives direct access to
     *         the value
     */
    public Enumeration<ListMode> getModeElement() {
      if (this.mode == null)
        if (Configuration.errorOnAutoCreate())
          throw new Error("Attempt to auto-create SectionComponent.mode");
        else if (Configuration.doAutoCreate())
          this.mode = new Enumeration<ListMode>(new ListModeEnumFactory()); // bb
      return this.mode;
    }

    public boolean hasModeElement() {
      return this.mode != null && !this.mode.isEmpty();
    }

    public boolean hasMode() {
      return this.mode != null && !this.mode.isEmpty();
    }

    /**
     * @param value {@link #mode} (How the entry list was prepared - whether it is a
     *              working list that is suitable for being maintained on an ongoing
     *              basis, or if it represents a snapshot of a list of items from
     *              another source, or whether it is a prepared list where items may
     *              be marked as added, modified or deleted.). This is the
     *              underlying object with id, value and extensions. The accessor
     *              "getMode" gives direct access to the value
     */
    public SectionComponent setModeElement(Enumeration<ListMode> value) {
      this.mode = value;
      return this;
    }

    /**
     * @return How the entry list was prepared - whether it is a working list that
     *         is suitable for being maintained on an ongoing basis, or if it
     *         represents a snapshot of a list of items from another source, or
     *         whether it is a prepared list where items may be marked as added,
     *         modified or deleted.
     */
    public ListMode getMode() {
      return this.mode == null ? null : this.mode.getValue();
    }

    /**
     * @param value How the entry list was prepared - whether it is a working list
     *              that is suitable for being maintained on an ongoing basis, or if
     *              it represents a snapshot of a list of items from another source,
     *              or whether it is a prepared list where items may be marked as
     *              added, modified or deleted.
     */
    public SectionComponent setMode(ListMode value) {
      if (value == null)
        this.mode = null;
      else {
        if (this.mode == null)
          this.mode = new Enumeration<ListMode>(new ListModeEnumFactory());
        this.mode.setValue(value);
      }
      return this;
    }

    /**
     * @return {@link #orderedBy} (Specifies the order applied to the items in the
     *         section entries.)
     */
    public CodeableConcept getOrderedBy() {
      if (this.orderedBy == null)
        if (Configuration.errorOnAutoCreate())
          throw new Error("Attempt to auto-create SectionComponent.orderedBy");
        else if (Configuration.doAutoCreate())
          this.orderedBy = new CodeableConcept(); // cc
      return this.orderedBy;
    }

    public boolean hasOrderedBy() {
      return this.orderedBy != null && !this.orderedBy.isEmpty();
    }

    /**
     * @param value {@link #orderedBy} (Specifies the order applied to the items in
     *              the section entries.)
     */
    public SectionComponent setOrderedBy(CodeableConcept value) {
      this.orderedBy = value;
      return this;
    }

    /**
     * @return {@link #entryClassifier} (Specifies any type of classification of the
     *         evidence report.)
     */
    public List<CodeableConcept> getEntryClassifier() {
      if (this.entryClassifier == null)
        this.entryClassifier = new ArrayList<CodeableConcept>();
      return this.entryClassifier;
    }

    /**
     * @return Returns a reference to <code>this</code> for easy method chaining
     */
    public SectionComponent setEntryClassifier(List<CodeableConcept> theEntryClassifier) {
      this.entryClassifier = theEntryClassifier;
      return this;
    }

    public boolean hasEntryClassifier() {
      if (this.entryClassifier == null)
        return false;
      for (CodeableConcept item : this.entryClassifier)
        if (!item.isEmpty())
          return true;
      return false;
    }

    public CodeableConcept addEntryClassifier() { // 3
      CodeableConcept t = new CodeableConcept();
      if (this.entryClassifier == null)
        this.entryClassifier = new ArrayList<CodeableConcept>();
      this.entryClassifier.add(t);
      return t;
    }

    public SectionComponent addEntryClassifier(CodeableConcept t) { // 3
      if (t == null)
        return this;
      if (this.entryClassifier == null)
        this.entryClassifier = new ArrayList<CodeableConcept>();
      this.entryClassifier.add(t);
      return this;
    }

    /**
     * @return The first repetition of repeating field {@link #entryClassifier},
     *         creating it if it does not already exist {3}
     */
    public CodeableConcept getEntryClassifierFirstRep() {
      if (getEntryClassifier().isEmpty()) {
        addEntryClassifier();
      }
      return getEntryClassifier().get(0);
    }

    /**
     * @return {@link #entryReference} (A reference to the actual resource from
     *         which the narrative in the section is derived.)
     */
    public List<Reference> getEntryReference() {
      if (this.entryReference == null)
        this.entryReference = new ArrayList<Reference>();
      return this.entryReference;
    }

    /**
     * @return Returns a reference to <code>this</code> for easy method chaining
     */
    public SectionComponent setEntryReference(List<Reference> theEntryReference) {
      this.entryReference = theEntryReference;
      return this;
    }

    public boolean hasEntryReference() {
      if (this.entryReference == null)
        return false;
      for (Reference item : this.entryReference)
        if (!item.isEmpty())
          return true;
      return false;
    }

    public Reference addEntryReference() { // 3
      Reference t = new Reference();
      if (this.entryReference == null)
        this.entryReference = new ArrayList<Reference>();
      this.entryReference.add(t);
      return t;
    }

    public SectionComponent addEntryReference(Reference t) { // 3
      if (t == null)
        return this;
      if (this.entryReference == null)
        this.entryReference = new ArrayList<Reference>();
      this.entryReference.add(t);
      return this;
    }

    /**
     * @return The first repetition of repeating field {@link #entryReference},
     *         creating it if it does not already exist {3}
     */
    public Reference getEntryReferenceFirstRep() {
      if (getEntryReference().isEmpty()) {
        addEntryReference();
      }
      return getEntryReference().get(0);
    }

    /**
     * @return {@link #entryQuantity} (Quantity as content.)
     */
    public List<Quantity> getEntryQuantity() {
      if (this.entryQuantity == null)
        this.entryQuantity = new ArrayList<Quantity>();
      return this.entryQuantity;
    }

    /**
     * @return Returns a reference to <code>this</code> for easy method chaining
     */
    public SectionComponent setEntryQuantity(List<Quantity> theEntryQuantity) {
      this.entryQuantity = theEntryQuantity;
      return this;
    }

    public boolean hasEntryQuantity() {
      if (this.entryQuantity == null)
        return false;
      for (Quantity item : this.entryQuantity)
        if (!item.isEmpty())
          return true;
      return false;
    }

    public Quantity addEntryQuantity() { // 3
      Quantity t = new Quantity();
      if (this.entryQuantity == null)
        this.entryQuantity = new ArrayList<Quantity>();
      this.entryQuantity.add(t);
      return t;
    }

    public SectionComponent addEntryQuantity(Quantity t) { // 3
      if (t == null)
        return this;
      if (this.entryQuantity == null)
        this.entryQuantity = new ArrayList<Quantity>();
      this.entryQuantity.add(t);
      return this;
    }

    /**
     * @return The first repetition of repeating field {@link #entryQuantity},
     *         creating it if it does not already exist {3}
     */
    public Quantity getEntryQuantityFirstRep() {
      if (getEntryQuantity().isEmpty()) {
        addEntryQuantity();
      }
      return getEntryQuantity().get(0);
    }

    /**
     * @return {@link #emptyReason} (If the section is empty, why the list is empty.
     *         An empty section typically has some text explaining the empty
     *         reason.)
     */
    public CodeableConcept getEmptyReason() {
      if (this.emptyReason == null)
        if (Configuration.errorOnAutoCreate())
          throw new Error("Attempt to auto-create SectionComponent.emptyReason");
        else if (Configuration.doAutoCreate())
          this.emptyReason = new CodeableConcept(); // cc
      return this.emptyReason;
    }

    public boolean hasEmptyReason() {
      return this.emptyReason != null && !this.emptyReason.isEmpty();
    }

    /**
     * @param value {@link #emptyReason} (If the section is empty, why the list is
     *              empty. An empty section typically has some text explaining the
     *              empty reason.)
     */
    public SectionComponent setEmptyReason(CodeableConcept value) {
      this.emptyReason = value;
      return this;
    }

    /**
     * @return {@link #section} (A nested sub-section within this section.)
     */
    public List<SectionComponent> getSection() {
      if (this.section == null)
        this.section = new ArrayList<SectionComponent>();
      return this.section;
    }

    /**
     * @return Returns a reference to <code>this</code> for easy method chaining
     */
    public SectionComponent setSection(List<SectionComponent> theSection) {
      this.section = theSection;
      return this;
    }

    public boolean hasSection() {
      if (this.section == null)
        return false;
      for (SectionComponent item : this.section)
        if (!item.isEmpty())
          return true;
      return false;
    }

    public SectionComponent addSection() { // 3
      SectionComponent t = new SectionComponent();
      if (this.section == null)
        this.section = new ArrayList<SectionComponent>();
      this.section.add(t);
      return t;
    }

    public SectionComponent addSection(SectionComponent t) { // 3
      if (t == null)
        return this;
      if (this.section == null)
        this.section = new ArrayList<SectionComponent>();
      this.section.add(t);
      return this;
    }

    /**
     * @return The first repetition of repeating field {@link #section}, creating it
     *         if it does not already exist {3}
     */
    public SectionComponent getSectionFirstRep() {
      if (getSection().isEmpty()) {
        addSection();
      }
      return getSection().get(0);
    }

    protected void listChildren(List<Property> children) {
      super.listChildren(children);
      children.add(new Property("title", "string",
          "The label for this particular section.  This will be part of the rendered content for the document, and is often used to build a table of contents.",
          0, 1, title));
      children.add(new Property("focus", "CodeableConcept",
          "A code identifying the kind of content contained within the section. This should be consistent with the section title.",
          0, 1, focus));
      children.add(new Property("focusReference", "Reference(Any)",
          "A definitional Resource identifying the kind of content contained within the section. This should be consistent with the section title.",
          0, 1, focusReference));
      children.add(new Property("author", "Reference(Person|Device|Group|Organization)",
          "Identifies who is responsible for the information in this section, not necessarily who typed it in.", 0,
          java.lang.Integer.MAX_VALUE, author));
      children.add(new Property("text", "Narrative",
          "A human-readable narrative that contains the attested content of the section, used to represent the content of the resource to a human. The narrative need not encode all the structured data, but is peferred to contain sufficient detail to make it acceptable for a human to just read the narrative.",
          0, 1, text));
      children.add(new Property("mode", "code",
          "How the entry list was prepared - whether it is a working list that is suitable for being maintained on an ongoing basis, or if it represents a snapshot of a list of items from another source, or whether it is a prepared list where items may be marked as added, modified or deleted.",
          0, 1, mode));
      children.add(new Property("orderedBy", "CodeableConcept",
          "Specifies the order applied to the items in the section entries.", 0, 1, orderedBy));
      children.add(new Property("entryClassifier", "CodeableConcept",
          "Specifies any type of classification of the evidence report.", 0, java.lang.Integer.MAX_VALUE,
          entryClassifier));
      children.add(new Property("entryReference", "Reference(Any)",
          "A reference to the actual resource from which the narrative in the section is derived.", 0,
          java.lang.Integer.MAX_VALUE, entryReference));
      children.add(new Property("entryQuantity", "Quantity", "Quantity as content.", 0, java.lang.Integer.MAX_VALUE,
          entryQuantity));
      children.add(new Property("emptyReason", "CodeableConcept",
          "If the section is empty, why the list is empty. An empty section typically has some text explaining the empty reason.",
          0, 1, emptyReason));
      children.add(new Property("section", "@EvidenceReport.section", "A nested sub-section within this section.", 0,
          java.lang.Integer.MAX_VALUE, section));
    }

    @Override
    public Property getNamedProperty(int _hash, String _name, boolean _checkValid) throws FHIRException {
      switch (_hash) {
      case 110371416:
        /* title */ return new Property("title", "string",
            "The label for this particular section.  This will be part of the rendered content for the document, and is often used to build a table of contents.",
            0, 1, title);
      case 97604824:
        /* focus */ return new Property("focus", "CodeableConcept",
            "A code identifying the kind of content contained within the section. This should be consistent with the section title.",
            0, 1, focus);
      case 1823604051:
        /* focusReference */ return new Property("focusReference", "Reference(Any)",
            "A definitional Resource identifying the kind of content contained within the section. This should be consistent with the section title.",
            0, 1, focusReference);
      case -1406328437:
        /* author */ return new Property("author", "Reference(Person|Device|Group|Organization)",
            "Identifies who is responsible for the information in this section, not necessarily who typed it in.", 0,
            java.lang.Integer.MAX_VALUE, author);
      case 3556653:
        /* text */ return new Property("text", "Narrative",
            "A human-readable narrative that contains the attested content of the section, used to represent the content of the resource to a human. The narrative need not encode all the structured data, but is peferred to contain sufficient detail to make it acceptable for a human to just read the narrative.",
            0, 1, text);
      case 3357091:
        /* mode */ return new Property("mode", "code",
            "How the entry list was prepared - whether it is a working list that is suitable for being maintained on an ongoing basis, or if it represents a snapshot of a list of items from another source, or whether it is a prepared list where items may be marked as added, modified or deleted.",
            0, 1, mode);
      case -391079516:
        /* orderedBy */ return new Property("orderedBy", "CodeableConcept",
            "Specifies the order applied to the items in the section entries.", 0, 1, orderedBy);
      case -948201421:
        /* entryClassifier */ return new Property("entryClassifier", "CodeableConcept",
            "Specifies any type of classification of the evidence report.", 0, java.lang.Integer.MAX_VALUE,
            entryClassifier);
      case 438810361:
        /* entryReference */ return new Property("entryReference", "Reference(Any)",
            "A reference to the actual resource from which the narrative in the section is derived.", 0,
            java.lang.Integer.MAX_VALUE, entryReference);
      case 1945583389:
        /* entryQuantity */ return new Property("entryQuantity", "Quantity", "Quantity as content.", 0,
            java.lang.Integer.MAX_VALUE, entryQuantity);
      case 1140135409:
        /* emptyReason */ return new Property("emptyReason", "CodeableConcept",
            "If the section is empty, why the list is empty. An empty section typically has some text explaining the empty reason.",
            0, 1, emptyReason);
      case 1970241253:
        /* section */ return new Property("section", "@EvidenceReport.section",
            "A nested sub-section within this section.", 0, java.lang.Integer.MAX_VALUE, section);
      default:
        return super.getNamedProperty(_hash, _name, _checkValid);
      }

    }

    @Override
    public Base[] getProperty(int hash, String name, boolean checkValid) throws FHIRException {
      switch (hash) {
      case 110371416:
        /* title */ return this.title == null ? new Base[0] : new Base[] { this.title }; // StringType
      case 97604824:
        /* focus */ return this.focus == null ? new Base[0] : new Base[] { this.focus }; // CodeableConcept
      case 1823604051:
        /* focusReference */ return this.focusReference == null ? new Base[0] : new Base[] { this.focusReference }; // Reference
      case -1406328437:
        /* author */ return this.author == null ? new Base[0] : this.author.toArray(new Base[this.author.size()]); // Reference
      case 3556653:
        /* text */ return this.text == null ? new Base[0] : new Base[] { this.text }; // Narrative
      case 3357091:
        /* mode */ return this.mode == null ? new Base[0] : new Base[] { this.mode }; // Enumeration<ListMode>
      case -391079516:
        /* orderedBy */ return this.orderedBy == null ? new Base[0] : new Base[] { this.orderedBy }; // CodeableConcept
      case -948201421:
        /* entryClassifier */ return this.entryClassifier == null ? new Base[0]
            : this.entryClassifier.toArray(new Base[this.entryClassifier.size()]); // CodeableConcept
      case 438810361:
        /* entryReference */ return this.entryReference == null ? new Base[0]
            : this.entryReference.toArray(new Base[this.entryReference.size()]); // Reference
      case 1945583389:
        /* entryQuantity */ return this.entryQuantity == null ? new Base[0]
            : this.entryQuantity.toArray(new Base[this.entryQuantity.size()]); // Quantity
      case 1140135409:
        /* emptyReason */ return this.emptyReason == null ? new Base[0] : new Base[] { this.emptyReason }; // CodeableConcept
      case 1970241253:
        /* section */ return this.section == null ? new Base[0] : this.section.toArray(new Base[this.section.size()]); // SectionComponent
      default:
        return super.getProperty(hash, name, checkValid);
      }

    }

    @Override
    public Base setProperty(int hash, String name, Base value) throws FHIRException {
      switch (hash) {
      case 110371416: // title
        this.title = TypeConvertor.castToString(value); // StringType
        return value;
      case 97604824: // focus
        this.focus = TypeConvertor.castToCodeableConcept(value); // CodeableConcept
        return value;
      case 1823604051: // focusReference
        this.focusReference = TypeConvertor.castToReference(value); // Reference
        return value;
      case -1406328437: // author
        this.getAuthor().add(TypeConvertor.castToReference(value)); // Reference
        return value;
      case 3556653: // text
        this.text = TypeConvertor.castToNarrative(value); // Narrative
        return value;
      case 3357091: // mode
        value = new ListModeEnumFactory().fromType(TypeConvertor.castToCode(value));
        this.mode = (Enumeration) value; // Enumeration<ListMode>
        return value;
      case -391079516: // orderedBy
        this.orderedBy = TypeConvertor.castToCodeableConcept(value); // CodeableConcept
        return value;
      case -948201421: // entryClassifier
        this.getEntryClassifier().add(TypeConvertor.castToCodeableConcept(value)); // CodeableConcept
        return value;
      case 438810361: // entryReference
        this.getEntryReference().add(TypeConvertor.castToReference(value)); // Reference
        return value;
      case 1945583389: // entryQuantity
        this.getEntryQuantity().add(TypeConvertor.castToQuantity(value)); // Quantity
        return value;
      case 1140135409: // emptyReason
        this.emptyReason = TypeConvertor.castToCodeableConcept(value); // CodeableConcept
        return value;
      case 1970241253: // section
        this.getSection().add((SectionComponent) value); // SectionComponent
        return value;
      default:
        return super.setProperty(hash, name, value);
      }

    }

    @Override
    public Base setProperty(String name, Base value) throws FHIRException {
      if (name.equals("title")) {
        this.title = TypeConvertor.castToString(value); // StringType
      } else if (name.equals("focus")) {
        this.focus = TypeConvertor.castToCodeableConcept(value); // CodeableConcept
      } else if (name.equals("focusReference")) {
        this.focusReference = TypeConvertor.castToReference(value); // Reference
      } else if (name.equals("author")) {
        this.getAuthor().add(TypeConvertor.castToReference(value));
      } else if (name.equals("text")) {
        this.text = TypeConvertor.castToNarrative(value); // Narrative
      } else if (name.equals("mode")) {
        value = new ListModeEnumFactory().fromType(TypeConvertor.castToCode(value));
        this.mode = (Enumeration) value; // Enumeration<ListMode>
      } else if (name.equals("orderedBy")) {
        this.orderedBy = TypeConvertor.castToCodeableConcept(value); // CodeableConcept
      } else if (name.equals("entryClassifier")) {
        this.getEntryClassifier().add(TypeConvertor.castToCodeableConcept(value));
      } else if (name.equals("entryReference")) {
        this.getEntryReference().add(TypeConvertor.castToReference(value));
      } else if (name.equals("entryQuantity")) {
        this.getEntryQuantity().add(TypeConvertor.castToQuantity(value));
      } else if (name.equals("emptyReason")) {
        this.emptyReason = TypeConvertor.castToCodeableConcept(value); // CodeableConcept
      } else if (name.equals("section")) {
        this.getSection().add((SectionComponent) value);
      } else
        return super.setProperty(name, value);
      return value;
    }

  @Override
  public void removeChild(String name, Base value) throws FHIRException {
      if (name.equals("title")) {
        this.title = null;
      } else if (name.equals("focus")) {
        this.focus = null;
      } else if (name.equals("focusReference")) {
        this.focusReference = null;
      } else if (name.equals("author")) {
        this.getAuthor().remove(value);
      } else if (name.equals("text")) {
        this.text = null;
      } else if (name.equals("mode")) {
        this.mode = null;
      } else if (name.equals("orderedBy")) {
        this.orderedBy = null;
      } else if (name.equals("entryClassifier")) {
        this.getEntryClassifier().remove(value);
      } else if (name.equals("entryReference")) {
        this.getEntryReference().remove(value);
      } else if (name.equals("entryQuantity")) {
        this.getEntryQuantity().remove(value);
      } else if (name.equals("emptyReason")) {
        this.emptyReason = null;
      } else if (name.equals("section")) {
        this.getSection().remove((SectionComponent) value);
      } else
        super.removeChild(name, value);
      
    }

    @Override
    public Base makeProperty(int hash, String name) throws FHIRException {
      switch (hash) {
      case 110371416:
        return getTitleElement();
      case 97604824:
        return getFocus();
      case 1823604051:
        return getFocusReference();
      case -1406328437:
        return addAuthor();
      case 3556653:
        return getText();
      case 3357091:
        return getModeElement();
      case -391079516:
        return getOrderedBy();
      case -948201421:
        return addEntryClassifier();
      case 438810361:
        return addEntryReference();
      case 1945583389:
        return addEntryQuantity();
      case 1140135409:
        return getEmptyReason();
      case 1970241253:
        return addSection();
      default:
        return super.makeProperty(hash, name);
      }

    }

    @Override
    public String[] getTypesForProperty(int hash, String name) throws FHIRException {
      switch (hash) {
      case 110371416:
        /* title */ return new String[] { "string" };
      case 97604824:
        /* focus */ return new String[] { "CodeableConcept" };
      case 1823604051:
        /* focusReference */ return new String[] { "Reference" };
      case -1406328437:
        /* author */ return new String[] { "Reference" };
      case 3556653:
        /* text */ return new String[] { "Narrative" };
      case 3357091:
        /* mode */ return new String[] { "code" };
      case -391079516:
        /* orderedBy */ return new String[] { "CodeableConcept" };
      case -948201421:
        /* entryClassifier */ return new String[] { "CodeableConcept" };
      case 438810361:
        /* entryReference */ return new String[] { "Reference" };
      case 1945583389:
        /* entryQuantity */ return new String[] { "Quantity" };
      case 1140135409:
        /* emptyReason */ return new String[] { "CodeableConcept" };
      case 1970241253:
        /* section */ return new String[] { "@EvidenceReport.section" };
      default:
        return super.getTypesForProperty(hash, name);
      }

    }

    @Override
    public Base addChild(String name) throws FHIRException {
      if (name.equals("title")) {
        throw new FHIRException("Cannot call addChild on a singleton property EvidenceReport.section.title");
      } else if (name.equals("focus")) {
        this.focus = new CodeableConcept();
        return this.focus;
      } else if (name.equals("focusReference")) {
        this.focusReference = new Reference();
        return this.focusReference;
      } else if (name.equals("author")) {
        return addAuthor();
      } else if (name.equals("text")) {
        this.text = new Narrative();
        return this.text;
      } else if (name.equals("mode")) {
        throw new FHIRException("Cannot call addChild on a singleton property EvidenceReport.section.mode");
      } else if (name.equals("orderedBy")) {
        this.orderedBy = new CodeableConcept();
        return this.orderedBy;
      } else if (name.equals("entryClassifier")) {
        return addEntryClassifier();
      } else if (name.equals("entryReference")) {
        return addEntryReference();
      } else if (name.equals("entryQuantity")) {
        return addEntryQuantity();
      } else if (name.equals("emptyReason")) {
        this.emptyReason = new CodeableConcept();
        return this.emptyReason;
      } else if (name.equals("section")) {
        return addSection();
      } else
        return super.addChild(name);
    }

    public SectionComponent copy() {
      SectionComponent dst = new SectionComponent();
      copyValues(dst);
      return dst;
    }

    public void copyValues(SectionComponent dst) {
      super.copyValues(dst);
      dst.title = title == null ? null : title.copy();
      dst.focus = focus == null ? null : focus.copy();
      dst.focusReference = focusReference == null ? null : focusReference.copy();
      if (author != null) {
        dst.author = new ArrayList<Reference>();
        for (Reference i : author)
          dst.author.add(i.copy());
      }
      ;
      dst.text = text == null ? null : text.copy();
      dst.mode = mode == null ? null : mode.copy();
      dst.orderedBy = orderedBy == null ? null : orderedBy.copy();
      if (entryClassifier != null) {
        dst.entryClassifier = new ArrayList<CodeableConcept>();
        for (CodeableConcept i : entryClassifier)
          dst.entryClassifier.add(i.copy());
      }
      ;
      if (entryReference != null) {
        dst.entryReference = new ArrayList<Reference>();
        for (Reference i : entryReference)
          dst.entryReference.add(i.copy());
      }
      ;
      if (entryQuantity != null) {
        dst.entryQuantity = new ArrayList<Quantity>();
        for (Quantity i : entryQuantity)
          dst.entryQuantity.add(i.copy());
      }
      ;
      dst.emptyReason = emptyReason == null ? null : emptyReason.copy();
      if (section != null) {
        dst.section = new ArrayList<SectionComponent>();
        for (SectionComponent i : section)
          dst.section.add(i.copy());
      }
      ;
    }

    @Override
    public boolean equalsDeep(Base other_) {
      if (!super.equalsDeep(other_))
        return false;
      if (!(other_ instanceof SectionComponent))
        return false;
      SectionComponent o = (SectionComponent) other_;
      return compareDeep(title, o.title, true) && compareDeep(focus, o.focus, true)
          && compareDeep(focusReference, o.focusReference, true) && compareDeep(author, o.author, true)
          && compareDeep(text, o.text, true) && compareDeep(mode, o.mode, true)
          && compareDeep(orderedBy, o.orderedBy, true) && compareDeep(entryClassifier, o.entryClassifier, true)
          && compareDeep(entryReference, o.entryReference, true) && compareDeep(entryQuantity, o.entryQuantity, true)
          && compareDeep(emptyReason, o.emptyReason, true) && compareDeep(section, o.section, true);
    }

    @Override
    public boolean equalsShallow(Base other_) {
      if (!super.equalsShallow(other_))
        return false;
      if (!(other_ instanceof SectionComponent))
        return false;
      SectionComponent o = (SectionComponent) other_;
      return compareValues(title, o.title, true) && compareValues(mode, o.mode, true);
    }

    public boolean isEmpty() {
      return super.isEmpty() && ca.uhn.fhir.util.ElementUtil.isEmpty(title, focus, focusReference, author, text, mode,
          orderedBy, entryClassifier, entryReference, entryQuantity, emptyReason, section);
    }

    public String fhirType() {
      return "EvidenceReport.section";

    }

  }

  /**
   * An absolute URI that is used to identify this EvidenceReport when it is
   * referenced in a specification, model, design or an instance; also called its
   * canonical identifier. This SHOULD be globally unique and SHOULD be a literal
   * address at which at which an authoritative instance of this summary is (or
   * will be) published. This URL can be the target of a canonical reference. It
   * SHALL remain the same when the summary is stored on different servers.
   */
  @Child(name = "url", type = { UriType.class }, order = 0, min = 0, max = 1, modifier = false, summary = true)
  @Description(shortDefinition = "Canonical identifier for this EvidenceReport, represented as a globally unique URI", formalDefinition = "An absolute URI that is used to identify this EvidenceReport when it is referenced in a specification, model, design or an instance; also called its canonical identifier. This SHOULD be globally unique and SHOULD be a literal address at which at which an authoritative instance of this summary is (or will be) published. This URL can be the target of a canonical reference. It SHALL remain the same when the summary is stored on different servers.")
  protected UriType url;

  /**
   * The status of this summary. Enables tracking the life-cycle of the content.
   */
  @Child(name = "status", type = { CodeType.class }, order = 1, min = 1, max = 1, modifier = true, summary = true)
  @Description(shortDefinition = "draft | active | retired | unknown", formalDefinition = "The status of this summary. Enables tracking the life-cycle of the content.")
  @ca.uhn.fhir.model.api.annotation.Binding(valueSet = "http://hl7.org/fhir/ValueSet/publication-status")
  protected Enumeration<PublicationStatus> status;

  /**
   * The content was developed with a focus and intent of supporting the contexts
   * that are listed. These contexts may be general categories (gender, age, ...)
   * or may be references to specific programs (insurance plans, studies, ...) and
   * may be used to assist with indexing and searching for appropriate evidence
   * report instances.
   */
  @Child(name = "useContext", type = {
      UsageContext.class }, order = 2, min = 0, max = Child.MAX_UNLIMITED, modifier = false, summary = true)
  @Description(shortDefinition = "The context that the content is intended to support", formalDefinition = "The content was developed with a focus and intent of supporting the contexts that are listed. These contexts may be general categories (gender, age, ...) or may be references to specific programs (insurance plans, studies, ...) and may be used to assist with indexing and searching for appropriate evidence report instances.")
  protected List<UsageContext> useContext;

  /**
   * A formal identifier that is used to identify this EvidenceReport when it is
   * represented in other formats, or referenced in a specification, model, design
   * or an instance.
   */
  @Child(name = "identifier", type = {
      Identifier.class }, order = 3, min = 0, max = Child.MAX_UNLIMITED, modifier = false, summary = true)
  @Description(shortDefinition = "Unique identifier for the evidence report", formalDefinition = "A formal identifier that is used to identify this EvidenceReport when it is represented in other formats, or referenced in a specification, model, design or an instance.")
  protected List<Identifier> identifier;

  /**
   * A formal identifier that is used to identify things closely related to this
   * EvidenceReport.
   */
  @Child(name = "relatedIdentifier", type = {
      Identifier.class }, order = 4, min = 0, max = Child.MAX_UNLIMITED, modifier = false, summary = true)
  @Description(shortDefinition = "Identifiers for articles that may relate to more than one evidence report", formalDefinition = "A formal identifier that is used to identify things closely related to this EvidenceReport.")
  protected List<Identifier> relatedIdentifier;

  /**
   * Citation Resource or display of suggested citation for this report.
   */
  @Child(name = "citeAs", type = { Citation.class,
      MarkdownType.class }, order = 5, min = 0, max = 1, modifier = false, summary = false)
  @Description(shortDefinition = "Citation for this report", formalDefinition = "Citation Resource or display of suggested citation for this report.")
  protected DataType citeAs;

  /**
   * Specifies the kind of report, such as grouping of classifiers, search
   * results, or human-compiled expression.
   */
  @Child(name = "type", type = {
      CodeableConcept.class }, order = 6, min = 0, max = 1, modifier = false, summary = false)
  @Description(shortDefinition = "Kind of report", formalDefinition = "Specifies the kind of report, such as grouping of classifiers, search results, or human-compiled expression.")
  @ca.uhn.fhir.model.api.annotation.Binding(valueSet = "http://hl7.org/fhir/ValueSet/evidence-report-type")
  protected CodeableConcept type;

  /**
   * Used for footnotes and annotations.
   */
  @Child(name = "note", type = {
      Annotation.class }, order = 7, min = 0, max = Child.MAX_UNLIMITED, modifier = false, summary = false)
  @Description(shortDefinition = "Used for footnotes and annotations", formalDefinition = "Used for footnotes and annotations.")
  protected List<Annotation> note;

  /**
   * Link, description or reference to artifact associated with the report.
   */
  @Child(name = "relatedArtifact", type = {
      RelatedArtifact.class }, order = 8, min = 0, max = Child.MAX_UNLIMITED, modifier = false, summary = false)
  @Description(shortDefinition = "Link, description or reference to artifact associated with the report", formalDefinition = "Link, description or reference to artifact associated with the report.")
  protected List<RelatedArtifact> relatedArtifact;

  /**
   * Specifies the subject or focus of the report. Answers "What is this report
   * about?".
   */
  @Child(name = "subject", type = {}, order = 9, min = 1, max = 1, modifier = false, summary = true)
  @Description(shortDefinition = "Focus of the report", formalDefinition = "Specifies the subject or focus of the report. Answers \"What is this report about?\".")
  protected EvidenceReportSubjectComponent subject;

  /**
   * The name of the organization or individual that published the evidence
   * report.
   */
  @Child(name = "publisher", type = {
      StringType.class }, order = 10, min = 0, max = 1, modifier = false, summary = true)
  @Description(shortDefinition = "Name of the publisher (organization or individual)", formalDefinition = "The name of the organization or individual that published the evidence report.")
  protected StringType publisher;

  /**
   * Contact details to assist a user in finding and communicating with the
   * publisher.
   */
  @Child(name = "contact", type = {
      ContactDetail.class }, order = 11, min = 0, max = Child.MAX_UNLIMITED, modifier = false, summary = true)
  @Description(shortDefinition = "Contact details for the publisher", formalDefinition = "Contact details to assist a user in finding and communicating with the publisher.")
  protected List<ContactDetail> contact;

  /**
   * An individiual, organization, or device primarily involved in the creation
   * and maintenance of the content.
   */
  @Child(name = "author", type = {
      ContactDetail.class }, order = 12, min = 0, max = Child.MAX_UNLIMITED, modifier = false, summary = true)
  @Description(shortDefinition = "Who authored the content", formalDefinition = "An individiual, organization, or device primarily involved in the creation and maintenance of the content.")
  protected List<ContactDetail> author;

  /**
   * An individiual, organization, or device primarily responsible for internal
   * coherence of the content.
   */
  @Child(name = "editor", type = {
      ContactDetail.class }, order = 13, min = 0, max = Child.MAX_UNLIMITED, modifier = false, summary = false)
  @Description(shortDefinition = "Who edited the content", formalDefinition = "An individiual, organization, or device primarily responsible for internal coherence of the content.")
  protected List<ContactDetail> editor;

  /**
   * An individiual, organization, or device primarily responsible for review of
   * some aspect of the content.
   */
  @Child(name = "reviewer", type = {
      ContactDetail.class }, order = 14, min = 0, max = Child.MAX_UNLIMITED, modifier = false, summary = false)
  @Description(shortDefinition = "Who reviewed the content", formalDefinition = "An individiual, organization, or device primarily responsible for review of some aspect of the content.")
  protected List<ContactDetail> reviewer;

  /**
   * An individiual, organization, or device responsible for officially endorsing
   * the content for use in some setting.
   */
  @Child(name = "endorser", type = {
      ContactDetail.class }, order = 15, min = 0, max = Child.MAX_UNLIMITED, modifier = false, summary = true)
  @Description(shortDefinition = "Who endorsed the content", formalDefinition = "An individiual, organization, or device responsible for officially endorsing the content for use in some setting.")
  protected List<ContactDetail> endorser;

  /**
   * Relationships that this composition has with other compositions or documents
   * that already exist.
   */
  @Child(name = "relatesTo", type = {}, order = 16, min = 0, max = Child.MAX_UNLIMITED, modifier = false, summary = false)
  @Description(shortDefinition = "Relationships to other compositions/documents", formalDefinition = "Relationships that this composition has with other compositions or documents that already exist.")
  protected List<EvidenceReportRelatesToComponent> relatesTo;

  /**
   * The root of the sections that make up the composition.
   */
  @Child(name = "section", type = {}, order = 17, min = 0, max = Child.MAX_UNLIMITED, modifier = false, summary = false)
  @Description(shortDefinition = "Composition is broken into sections", formalDefinition = "The root of the sections that make up the composition.")
  protected List<SectionComponent> section;

  private static final long serialVersionUID = -1087028792L;

  /**
   * Constructor
   */
  public EvidenceReport() {
    super();
  }

  /**
   * Constructor
   */
  public EvidenceReport(PublicationStatus status, EvidenceReportSubjectComponent subject) {
    super();
    this.setStatus(status);
    this.setSubject(subject);
  }

  /**
   * @return {@link #url} (An absolute URI that is used to identify this
   *         EvidenceReport when it is referenced in a specification, model,
   *         design or an instance; also called its canonical identifier. This
   *         SHOULD be globally unique and SHOULD be a literal address at which at
   *         which an authoritative instance of this summary is (or will be)
   *         published. This URL can be the target of a canonical reference. It
   *         SHALL remain the same when the summary is stored on different
   *         servers.). This is the underlying object with id, value and
   *         extensions. The accessor "getUrl" gives direct access to the value
   */
  public UriType getUrlElement() {
    if (this.url == null)
      if (Configuration.errorOnAutoCreate())
        throw new Error("Attempt to auto-create EvidenceReport.url");
      else if (Configuration.doAutoCreate())
        this.url = new UriType(); // bb
    return this.url;
  }

  public boolean hasUrlElement() {
    return this.url != null && !this.url.isEmpty();
  }

  public boolean hasUrl() {
    return this.url != null && !this.url.isEmpty();
  }

  /**
   * @param value {@link #url} (An absolute URI that is used to identify this
   *              EvidenceReport when it is referenced in a specification, model,
   *              design or an instance; also called its canonical identifier.
   *              This SHOULD be globally unique and SHOULD be a literal address
   *              at which at which an authoritative instance of this summary is
   *              (or will be) published. This URL can be the target of a
   *              canonical reference. It SHALL remain the same when the summary
   *              is stored on different servers.). This is the underlying object
   *              with id, value and extensions. The accessor "getUrl" gives
   *              direct access to the value
   */
  public EvidenceReport setUrlElement(UriType value) {
    this.url = value;
    return this;
  }

  /**
   * @return An absolute URI that is used to identify this EvidenceReport when it
   *         is referenced in a specification, model, design or an instance; also
   *         called its canonical identifier. This SHOULD be globally unique and
   *         SHOULD be a literal address at which at which an authoritative
   *         instance of this summary is (or will be) published. This URL can be
   *         the target of a canonical reference. It SHALL remain the same when
   *         the summary is stored on different servers.
   */
  public String getUrl() {
    return this.url == null ? null : this.url.getValue();
  }

  /**
   * @param value An absolute URI that is used to identify this EvidenceReport
   *              when it is referenced in a specification, model, design or an
   *              instance; also called its canonical identifier. This SHOULD be
   *              globally unique and SHOULD be a literal address at which at
   *              which an authoritative instance of this summary is (or will be)
   *              published. This URL can be the target of a canonical reference.
   *              It SHALL remain the same when the summary is stored on different
   *              servers.
   */
  public EvidenceReport setUrl(String value) {
    if (Utilities.noString(value))
      this.url = null;
    else {
      if (this.url == null)
        this.url = new UriType();
      this.url.setValue(value);
    }
    return this;
  }

  /**
   * @return {@link #status} (The status of this summary. Enables tracking the
   *         life-cycle of the content.). This is the underlying object with id,
   *         value and extensions. The accessor "getStatus" gives direct access to
   *         the value
   */
  public Enumeration<PublicationStatus> getStatusElement() {
    if (this.status == null)
      if (Configuration.errorOnAutoCreate())
        throw new Error("Attempt to auto-create EvidenceReport.status");
      else if (Configuration.doAutoCreate())
        this.status = new Enumeration<PublicationStatus>(new PublicationStatusEnumFactory()); // bb
    return this.status;
  }

  public boolean hasStatusElement() {
    return this.status != null && !this.status.isEmpty();
  }

  public boolean hasStatus() {
    return this.status != null && !this.status.isEmpty();
  }

  /**
   * @param value {@link #status} (The status of this summary. Enables tracking
   *              the life-cycle of the content.). This is the underlying object
   *              with id, value and extensions. The accessor "getStatus" gives
   *              direct access to the value
   */
  public EvidenceReport setStatusElement(Enumeration<PublicationStatus> value) {
    this.status = value;
    return this;
  }

  /**
   * @return The status of this summary. Enables tracking the life-cycle of the
   *         content.
   */
  public PublicationStatus getStatus() {
    return this.status == null ? null : this.status.getValue();
  }

  /**
   * @param value The status of this summary. Enables tracking the life-cycle of
   *              the content.
   */
  public EvidenceReport setStatus(PublicationStatus value) {
    if (this.status == null)
      this.status = new Enumeration<PublicationStatus>(new PublicationStatusEnumFactory());
    this.status.setValue(value);
    return this;
  }

  /**
   * @return {@link #useContext} (The content was developed with a focus and
   *         intent of supporting the contexts that are listed. These contexts may
   *         be general categories (gender, age, ...) or may be references to
   *         specific programs (insurance plans, studies, ...) and may be used to
   *         assist with indexing and searching for appropriate evidence report
   *         instances.)
   */
  public List<UsageContext> getUseContext() {
    if (this.useContext == null)
      this.useContext = new ArrayList<UsageContext>();
    return this.useContext;
  }

  /**
   * @return Returns a reference to <code>this</code> for easy method chaining
   */
  public EvidenceReport setUseContext(List<UsageContext> theUseContext) {
    this.useContext = theUseContext;
    return this;
  }

  public boolean hasUseContext() {
    if (this.useContext == null)
      return false;
    for (UsageContext item : this.useContext)
      if (!item.isEmpty())
        return true;
    return false;
  }

  public UsageContext addUseContext() { // 3
    UsageContext t = new UsageContext();
    if (this.useContext == null)
      this.useContext = new ArrayList<UsageContext>();
    this.useContext.add(t);
    return t;
  }

  public EvidenceReport addUseContext(UsageContext t) { // 3
    if (t == null)
      return this;
    if (this.useContext == null)
      this.useContext = new ArrayList<UsageContext>();
    this.useContext.add(t);
    return this;
  }

  /**
   * @return The first repetition of repeating field {@link #useContext}, creating
   *         it if it does not already exist {3}
   */
  public UsageContext getUseContextFirstRep() {
    if (getUseContext().isEmpty()) {
      addUseContext();
    }
    return getUseContext().get(0);
  }

  /**
   * @return {@link #identifier} (A formal identifier that is used to identify
   *         this EvidenceReport when it is represented in other formats, or
   *         referenced in a specification, model, design or an instance.)
   */
  public List<Identifier> getIdentifier() {
    if (this.identifier == null)
      this.identifier = new ArrayList<Identifier>();
    return this.identifier;
  }

  /**
   * @return Returns a reference to <code>this</code> for easy method chaining
   */
  public EvidenceReport setIdentifier(List<Identifier> theIdentifier) {
    this.identifier = theIdentifier;
    return this;
  }

  public boolean hasIdentifier() {
    if (this.identifier == null)
      return false;
    for (Identifier item : this.identifier)
      if (!item.isEmpty())
        return true;
    return false;
  }

  public Identifier addIdentifier() { // 3
    Identifier t = new Identifier();
    if (this.identifier == null)
      this.identifier = new ArrayList<Identifier>();
    this.identifier.add(t);
    return t;
  }

  public EvidenceReport addIdentifier(Identifier t) { // 3
    if (t == null)
      return this;
    if (this.identifier == null)
      this.identifier = new ArrayList<Identifier>();
    this.identifier.add(t);
    return this;
  }

  /**
   * @return The first repetition of repeating field {@link #identifier}, creating
   *         it if it does not already exist {3}
   */
  public Identifier getIdentifierFirstRep() {
    if (getIdentifier().isEmpty()) {
      addIdentifier();
    }
    return getIdentifier().get(0);
  }

  /**
   * @return {@link #relatedIdentifier} (A formal identifier that is used to
   *         identify things closely related to this EvidenceReport.)
   */
  public List<Identifier> getRelatedIdentifier() {
    if (this.relatedIdentifier == null)
      this.relatedIdentifier = new ArrayList<Identifier>();
    return this.relatedIdentifier;
  }

  /**
   * @return Returns a reference to <code>this</code> for easy method chaining
   */
  public EvidenceReport setRelatedIdentifier(List<Identifier> theRelatedIdentifier) {
    this.relatedIdentifier = theRelatedIdentifier;
    return this;
  }

  public boolean hasRelatedIdentifier() {
    if (this.relatedIdentifier == null)
      return false;
    for (Identifier item : this.relatedIdentifier)
      if (!item.isEmpty())
        return true;
    return false;
  }

  public Identifier addRelatedIdentifier() { // 3
    Identifier t = new Identifier();
    if (this.relatedIdentifier == null)
      this.relatedIdentifier = new ArrayList<Identifier>();
    this.relatedIdentifier.add(t);
    return t;
  }

  public EvidenceReport addRelatedIdentifier(Identifier t) { // 3
    if (t == null)
      return this;
    if (this.relatedIdentifier == null)
      this.relatedIdentifier = new ArrayList<Identifier>();
    this.relatedIdentifier.add(t);
    return this;
  }

  /**
   * @return The first repetition of repeating field {@link #relatedIdentifier},
   *         creating it if it does not already exist {3}
   */
  public Identifier getRelatedIdentifierFirstRep() {
    if (getRelatedIdentifier().isEmpty()) {
      addRelatedIdentifier();
    }
    return getRelatedIdentifier().get(0);
  }

  /**
   * @return {@link #citeAs} (Citation Resource or display of suggested citation
   *         for this report.)
   */
  public DataType getCiteAs() {
    return this.citeAs;
  }

  /**
   * @return {@link #citeAs} (Citation Resource or display of suggested citation
   *         for this report.)
   */
  public Reference getCiteAsReference() throws FHIRException {
    if (this.citeAs == null)
      this.citeAs = new Reference();
    if (!(this.citeAs instanceof Reference))
      throw new FHIRException("Type mismatch: the type Reference was expected, but " + this.citeAs.getClass().getName()
          + " was encountered");
    return (Reference) this.citeAs;
  }

  public boolean hasCiteAsReference() {
      return this.citeAs instanceof Reference;
  }

  /**
   * @return {@link #citeAs} (Citation Resource or display of suggested citation
   *         for this report.)
   */
  public MarkdownType getCiteAsMarkdownType() throws FHIRException {
    if (this.citeAs == null)
      this.citeAs = new MarkdownType();
    if (!(this.citeAs instanceof MarkdownType))
      throw new FHIRException("Type mismatch: the type MarkdownType was expected, but "
          + this.citeAs.getClass().getName() + " was encountered");
    return (MarkdownType) this.citeAs;
  }

  public boolean hasCiteAsMarkdownType() {
      return this.citeAs instanceof MarkdownType;
  }

  public boolean hasCiteAs() {
    return this.citeAs != null && !this.citeAs.isEmpty();
  }

  /**
   * @param value {@link #citeAs} (Citation Resource or display of suggested
   *              citation for this report.)
   */
  public EvidenceReport setCiteAs(DataType value) {
    if (value != null && !(value instanceof Reference || value instanceof MarkdownType))
      throw new Error("Not the right type for EvidenceReport.citeAs[x]: " + value.fhirType());
    this.citeAs = value;
    return this;
  }

  /**
   * @return {@link #type} (Specifies the kind of report, such as grouping of
   *         classifiers, search results, or human-compiled expression.)
   */
  public CodeableConcept getType() {
    if (this.type == null)
      if (Configuration.errorOnAutoCreate())
        throw new Error("Attempt to auto-create EvidenceReport.type");
      else if (Configuration.doAutoCreate())
        this.type = new CodeableConcept(); // cc
    return this.type;
  }

  public boolean hasType() {
    return this.type != null && !this.type.isEmpty();
  }

  /**
   * @param value {@link #type} (Specifies the kind of report, such as grouping of
   *              classifiers, search results, or human-compiled expression.)
   */
  public EvidenceReport setType(CodeableConcept value) {
    this.type = value;
    return this;
  }

  /**
   * @return {@link #note} (Used for footnotes and annotations.)
   */
  public List<Annotation> getNote() {
    if (this.note == null)
      this.note = new ArrayList<Annotation>();
    return this.note;
  }

  /**
   * @return Returns a reference to <code>this</code> for easy method chaining
   */
  public EvidenceReport setNote(List<Annotation> theNote) {
    this.note = theNote;
    return this;
  }

  public boolean hasNote() {
    if (this.note == null)
      return false;
    for (Annotation item : this.note)
      if (!item.isEmpty())
        return true;
    return false;
  }

  public Annotation addNote() { // 3
    Annotation t = new Annotation();
    if (this.note == null)
      this.note = new ArrayList<Annotation>();
    this.note.add(t);
    return t;
  }

  public EvidenceReport addNote(Annotation t) { // 3
    if (t == null)
      return this;
    if (this.note == null)
      this.note = new ArrayList<Annotation>();
    this.note.add(t);
    return this;
  }

  /**
   * @return The first repetition of repeating field {@link #note}, creating it if
   *         it does not already exist {3}
   */
  public Annotation getNoteFirstRep() {
    if (getNote().isEmpty()) {
      addNote();
    }
    return getNote().get(0);
  }

  /**
   * @return {@link #relatedArtifact} (Link, description or reference to artifact
   *         associated with the report.)
   */
  public List<RelatedArtifact> getRelatedArtifact() {
    if (this.relatedArtifact == null)
      this.relatedArtifact = new ArrayList<RelatedArtifact>();
    return this.relatedArtifact;
  }

  /**
   * @return Returns a reference to <code>this</code> for easy method chaining
   */
  public EvidenceReport setRelatedArtifact(List<RelatedArtifact> theRelatedArtifact) {
    this.relatedArtifact = theRelatedArtifact;
    return this;
  }

  public boolean hasRelatedArtifact() {
    if (this.relatedArtifact == null)
      return false;
    for (RelatedArtifact item : this.relatedArtifact)
      if (!item.isEmpty())
        return true;
    return false;
  }

  public RelatedArtifact addRelatedArtifact() { // 3
    RelatedArtifact t = new RelatedArtifact();
    if (this.relatedArtifact == null)
      this.relatedArtifact = new ArrayList<RelatedArtifact>();
    this.relatedArtifact.add(t);
    return t;
  }

  public EvidenceReport addRelatedArtifact(RelatedArtifact t) { // 3
    if (t == null)
      return this;
    if (this.relatedArtifact == null)
      this.relatedArtifact = new ArrayList<RelatedArtifact>();
    this.relatedArtifact.add(t);
    return this;
  }

  /**
   * @return The first repetition of repeating field {@link #relatedArtifact},
   *         creating it if it does not already exist {3}
   */
  public RelatedArtifact getRelatedArtifactFirstRep() {
    if (getRelatedArtifact().isEmpty()) {
      addRelatedArtifact();
    }
    return getRelatedArtifact().get(0);
  }

  /**
   * @return {@link #subject} (Specifies the subject or focus of the report.
   *         Answers "What is this report about?".)
   */
  public EvidenceReportSubjectComponent getSubject() {
    if (this.subject == null)
      if (Configuration.errorOnAutoCreate())
        throw new Error("Attempt to auto-create EvidenceReport.subject");
      else if (Configuration.doAutoCreate())
        this.subject = new EvidenceReportSubjectComponent(); // cc
    return this.subject;
  }

  public boolean hasSubject() {
    return this.subject != null && !this.subject.isEmpty();
  }

  /**
   * @param value {@link #subject} (Specifies the subject or focus of the report.
   *              Answers "What is this report about?".)
   */
  public EvidenceReport setSubject(EvidenceReportSubjectComponent value) {
    this.subject = value;
    return this;
  }

  /**
   * @return {@link #publisher} (The name of the organization or individual that
   *         published the evidence report.). This is the underlying object with
   *         id, value and extensions. The accessor "getPublisher" gives direct
   *         access to the value
   */
  public StringType getPublisherElement() {
    if (this.publisher == null)
      if (Configuration.errorOnAutoCreate())
        throw new Error("Attempt to auto-create EvidenceReport.publisher");
      else if (Configuration.doAutoCreate())
        this.publisher = new StringType(); // bb
    return this.publisher;
  }

  public boolean hasPublisherElement() {
    return this.publisher != null && !this.publisher.isEmpty();
  }

  public boolean hasPublisher() {
    return this.publisher != null && !this.publisher.isEmpty();
  }

  /**
   * @param value {@link #publisher} (The name of the organization or individual
   *              that published the evidence report.). This is the underlying
   *              object with id, value and extensions. The accessor
   *              "getPublisher" gives direct access to the value
   */
  public EvidenceReport setPublisherElement(StringType value) {
    this.publisher = value;
    return this;
  }

  /**
   * @return The name of the organization or individual that published the
   *         evidence report.
   */
  public String getPublisher() {
    return this.publisher == null ? null : this.publisher.getValue();
  }

  /**
   * @param value The name of the organization or individual that published the
   *              evidence report.
   */
  public EvidenceReport setPublisher(String value) {
    if (Utilities.noString(value))
      this.publisher = null;
    else {
      if (this.publisher == null)
        this.publisher = new StringType();
      this.publisher.setValue(value);
    }
    return this;
  }

  /**
   * @return {@link #contact} (Contact details to assist a user in finding and
   *         communicating with the publisher.)
   */
  public List<ContactDetail> getContact() {
    if (this.contact == null)
      this.contact = new ArrayList<ContactDetail>();
    return this.contact;
  }

  /**
   * @return Returns a reference to <code>this</code> for easy method chaining
   */
  public EvidenceReport setContact(List<ContactDetail> theContact) {
    this.contact = theContact;
    return this;
  }

  public boolean hasContact() {
    if (this.contact == null)
      return false;
    for (ContactDetail item : this.contact)
      if (!item.isEmpty())
        return true;
    return false;
  }

  public ContactDetail addContact() { // 3
    ContactDetail t = new ContactDetail();
    if (this.contact == null)
      this.contact = new ArrayList<ContactDetail>();
    this.contact.add(t);
    return t;
  }

  public EvidenceReport addContact(ContactDetail t) { // 3
    if (t == null)
      return this;
    if (this.contact == null)
      this.contact = new ArrayList<ContactDetail>();
    this.contact.add(t);
    return this;
  }

  /**
   * @return The first repetition of repeating field {@link #contact}, creating it
   *         if it does not already exist {3}
   */
  public ContactDetail getContactFirstRep() {
    if (getContact().isEmpty()) {
      addContact();
    }
    return getContact().get(0);
  }

  /**
   * @return {@link #author} (An individiual, organization, or device primarily
   *         involved in the creation and maintenance of the content.)
   */
  public List<ContactDetail> getAuthor() {
    if (this.author == null)
      this.author = new ArrayList<ContactDetail>();
    return this.author;
  }

  /**
   * @return Returns a reference to <code>this</code> for easy method chaining
   */
  public EvidenceReport setAuthor(List<ContactDetail> theAuthor) {
    this.author = theAuthor;
    return this;
  }

  public boolean hasAuthor() {
    if (this.author == null)
      return false;
    for (ContactDetail item : this.author)
      if (!item.isEmpty())
        return true;
    return false;
  }

  public ContactDetail addAuthor() { // 3
    ContactDetail t = new ContactDetail();
    if (this.author == null)
      this.author = new ArrayList<ContactDetail>();
    this.author.add(t);
    return t;
  }

  public EvidenceReport addAuthor(ContactDetail t) { // 3
    if (t == null)
      return this;
    if (this.author == null)
      this.author = new ArrayList<ContactDetail>();
    this.author.add(t);
    return this;
  }

  /**
   * @return The first repetition of repeating field {@link #author}, creating it
   *         if it does not already exist {3}
   */
  public ContactDetail getAuthorFirstRep() {
    if (getAuthor().isEmpty()) {
      addAuthor();
    }
    return getAuthor().get(0);
  }

  /**
   * @return {@link #editor} (An individiual, organization, or device primarily
   *         responsible for internal coherence of the content.)
   */
  public List<ContactDetail> getEditor() {
    if (this.editor == null)
      this.editor = new ArrayList<ContactDetail>();
    return this.editor;
  }

  /**
   * @return Returns a reference to <code>this</code> for easy method chaining
   */
  public EvidenceReport setEditor(List<ContactDetail> theEditor) {
    this.editor = theEditor;
    return this;
  }

  public boolean hasEditor() {
    if (this.editor == null)
      return false;
    for (ContactDetail item : this.editor)
      if (!item.isEmpty())
        return true;
    return false;
  }

  public ContactDetail addEditor() { // 3
    ContactDetail t = new ContactDetail();
    if (this.editor == null)
      this.editor = new ArrayList<ContactDetail>();
    this.editor.add(t);
    return t;
  }

  public EvidenceReport addEditor(ContactDetail t) { // 3
    if (t == null)
      return this;
    if (this.editor == null)
      this.editor = new ArrayList<ContactDetail>();
    this.editor.add(t);
    return this;
  }

  /**
   * @return The first repetition of repeating field {@link #editor}, creating it
   *         if it does not already exist {3}
   */
  public ContactDetail getEditorFirstRep() {
    if (getEditor().isEmpty()) {
      addEditor();
    }
    return getEditor().get(0);
  }

  /**
   * @return {@link #reviewer} (An individiual, organization, or device primarily
   *         responsible for review of some aspect of the content.)
   */
  public List<ContactDetail> getReviewer() {
    if (this.reviewer == null)
      this.reviewer = new ArrayList<ContactDetail>();
    return this.reviewer;
  }

  /**
   * @return Returns a reference to <code>this</code> for easy method chaining
   */
  public EvidenceReport setReviewer(List<ContactDetail> theReviewer) {
    this.reviewer = theReviewer;
    return this;
  }

  public boolean hasReviewer() {
    if (this.reviewer == null)
      return false;
    for (ContactDetail item : this.reviewer)
      if (!item.isEmpty())
        return true;
    return false;
  }

  public ContactDetail addReviewer() { // 3
    ContactDetail t = new ContactDetail();
    if (this.reviewer == null)
      this.reviewer = new ArrayList<ContactDetail>();
    this.reviewer.add(t);
    return t;
  }

  public EvidenceReport addReviewer(ContactDetail t) { // 3
    if (t == null)
      return this;
    if (this.reviewer == null)
      this.reviewer = new ArrayList<ContactDetail>();
    this.reviewer.add(t);
    return this;
  }

  /**
   * @return The first repetition of repeating field {@link #reviewer}, creating
   *         it if it does not already exist {3}
   */
  public ContactDetail getReviewerFirstRep() {
    if (getReviewer().isEmpty()) {
      addReviewer();
    }
    return getReviewer().get(0);
  }

  /**
   * @return {@link #endorser} (An individiual, organization, or device
   *         responsible for officially endorsing the content for use in some
   *         setting.)
   */
  public List<ContactDetail> getEndorser() {
    if (this.endorser == null)
      this.endorser = new ArrayList<ContactDetail>();
    return this.endorser;
  }

  /**
   * @return Returns a reference to <code>this</code> for easy method chaining
   */
  public EvidenceReport setEndorser(List<ContactDetail> theEndorser) {
    this.endorser = theEndorser;
    return this;
  }

  public boolean hasEndorser() {
    if (this.endorser == null)
      return false;
    for (ContactDetail item : this.endorser)
      if (!item.isEmpty())
        return true;
    return false;
  }

  public ContactDetail addEndorser() { // 3
    ContactDetail t = new ContactDetail();
    if (this.endorser == null)
      this.endorser = new ArrayList<ContactDetail>();
    this.endorser.add(t);
    return t;
  }

  public EvidenceReport addEndorser(ContactDetail t) { // 3
    if (t == null)
      return this;
    if (this.endorser == null)
      this.endorser = new ArrayList<ContactDetail>();
    this.endorser.add(t);
    return this;
  }

  /**
   * @return The first repetition of repeating field {@link #endorser}, creating
   *         it if it does not already exist {3}
   */
  public ContactDetail getEndorserFirstRep() {
    if (getEndorser().isEmpty()) {
      addEndorser();
    }
    return getEndorser().get(0);
  }

  /**
   * @return {@link #relatesTo} (Relationships that this composition has with
   *         other compositions or documents that already exist.)
   */
  public List<EvidenceReportRelatesToComponent> getRelatesTo() {
    if (this.relatesTo == null)
      this.relatesTo = new ArrayList<EvidenceReportRelatesToComponent>();
    return this.relatesTo;
  }

  /**
   * @return Returns a reference to <code>this</code> for easy method chaining
   */
  public EvidenceReport setRelatesTo(List<EvidenceReportRelatesToComponent> theRelatesTo) {
    this.relatesTo = theRelatesTo;
    return this;
  }

  public boolean hasRelatesTo() {
    if (this.relatesTo == null)
      return false;
    for (EvidenceReportRelatesToComponent item : this.relatesTo)
      if (!item.isEmpty())
        return true;
    return false;
  }

  public EvidenceReportRelatesToComponent addRelatesTo() { // 3
    EvidenceReportRelatesToComponent t = new EvidenceReportRelatesToComponent();
    if (this.relatesTo == null)
      this.relatesTo = new ArrayList<EvidenceReportRelatesToComponent>();
    this.relatesTo.add(t);
    return t;
  }

  public EvidenceReport addRelatesTo(EvidenceReportRelatesToComponent t) { // 3
    if (t == null)
      return this;
    if (this.relatesTo == null)
      this.relatesTo = new ArrayList<EvidenceReportRelatesToComponent>();
    this.relatesTo.add(t);
    return this;
  }

  /**
   * @return The first repetition of repeating field {@link #relatesTo}, creating
   *         it if it does not already exist {3}
   */
  public EvidenceReportRelatesToComponent getRelatesToFirstRep() {
    if (getRelatesTo().isEmpty()) {
      addRelatesTo();
    }
    return getRelatesTo().get(0);
  }

  /**
   * @return {@link #section} (The root of the sections that make up the
   *         composition.)
   */
  public List<SectionComponent> getSection() {
    if (this.section == null)
      this.section = new ArrayList<SectionComponent>();
    return this.section;
  }

  /**
   * @return Returns a reference to <code>this</code> for easy method chaining
   */
  public EvidenceReport setSection(List<SectionComponent> theSection) {
    this.section = theSection;
    return this;
  }

  public boolean hasSection() {
    if (this.section == null)
      return false;
    for (SectionComponent item : this.section)
      if (!item.isEmpty())
        return true;
    return false;
  }

  public SectionComponent addSection() { // 3
    SectionComponent t = new SectionComponent();
    if (this.section == null)
      this.section = new ArrayList<SectionComponent>();
    this.section.add(t);
    return t;
  }

  public EvidenceReport addSection(SectionComponent t) { // 3
    if (t == null)
      return this;
    if (this.section == null)
      this.section = new ArrayList<SectionComponent>();
    this.section.add(t);
    return this;
  }

  /**
   * @return The first repetition of repeating field {@link #section}, creating it
   *         if it does not already exist {3}
   */
  public SectionComponent getSectionFirstRep() {
    if (getSection().isEmpty()) {
      addSection();
    }
    return getSection().get(0);
  }

  protected void listChildren(List<Property> children) {
    super.listChildren(children);
    children.add(new Property("url", "uri",
        "An absolute URI that is used to identify this EvidenceReport when it is referenced in a specification, model, design or an instance; also called its canonical identifier. This SHOULD be globally unique and SHOULD be a literal address at which at which an authoritative instance of this summary is (or will be) published. This URL can be the target of a canonical reference. It SHALL remain the same when the summary is stored on different servers.",
        0, 1, url));
    children.add(new Property("status", "code",
        "The status of this summary. Enables tracking the life-cycle of the content.", 0, 1, status));
    children.add(new Property("useContext", "UsageContext",
        "The content was developed with a focus and intent of supporting the contexts that are listed. These contexts may be general categories (gender, age, ...) or may be references to specific programs (insurance plans, studies, ...) and may be used to assist with indexing and searching for appropriate evidence report instances.",
        0, java.lang.Integer.MAX_VALUE, useContext));
    children.add(new Property("identifier", "Identifier",
        "A formal identifier that is used to identify this EvidenceReport when it is represented in other formats, or referenced in a specification, model, design or an instance.",
        0, java.lang.Integer.MAX_VALUE, identifier));
    children.add(new Property("relatedIdentifier", "Identifier",
        "A formal identifier that is used to identify things closely related to this EvidenceReport.", 0,
        java.lang.Integer.MAX_VALUE, relatedIdentifier));
    children.add(new Property("citeAs[x]", "Reference(Citation)|markdown",
        "Citation Resource or display of suggested citation for this report.", 0, 1, citeAs));
    children.add(new Property("type", "CodeableConcept",
        "Specifies the kind of report, such as grouping of classifiers, search results, or human-compiled expression.",
        0, 1, type));
    children.add(new Property("note", "Annotation", "Used for footnotes and annotations.", 0,
        java.lang.Integer.MAX_VALUE, note));
    children.add(new Property("relatedArtifact", "RelatedArtifact",
        "Link, description or reference to artifact associated with the report.", 0, java.lang.Integer.MAX_VALUE,
        relatedArtifact));
    children.add(new Property("subject", "",
        "Specifies the subject or focus of the report. Answers \"What is this report about?\".", 0, 1, subject));
    children.add(new Property("publisher", "string",
        "The name of the organization or individual that published the evidence report.", 0, 1, publisher));
    children.add(new Property("contact", "ContactDetail",
        "Contact details to assist a user in finding and communicating with the publisher.", 0,
        java.lang.Integer.MAX_VALUE, contact));
    children.add(new Property("author", "ContactDetail",
        "An individiual, organization, or device primarily involved in the creation and maintenance of the content.", 0,
        java.lang.Integer.MAX_VALUE, author));
    children.add(new Property("editor", "ContactDetail",
        "An individiual, organization, or device primarily responsible for internal coherence of the content.", 0,
        java.lang.Integer.MAX_VALUE, editor));
    children.add(new Property("reviewer", "ContactDetail",
        "An individiual, organization, or device primarily responsible for review of some aspect of the content.", 0,
        java.lang.Integer.MAX_VALUE, reviewer));
    children.add(new Property("endorser", "ContactDetail",
        "An individiual, organization, or device responsible for officially endorsing the content for use in some setting.",
        0, java.lang.Integer.MAX_VALUE, endorser));
    children.add(new Property("relatesTo", "",
        "Relationships that this composition has with other compositions or documents that already exist.", 0,
        java.lang.Integer.MAX_VALUE, relatesTo));
    children.add(new Property("section", "", "The root of the sections that make up the composition.", 0,
        java.lang.Integer.MAX_VALUE, section));
  }

  @Override
  public Property getNamedProperty(int _hash, String _name, boolean _checkValid) throws FHIRException {
    switch (_hash) {
    case 116079:
      /* url */ return new Property("url", "uri",
          "An absolute URI that is used to identify this EvidenceReport when it is referenced in a specification, model, design or an instance; also called its canonical identifier. This SHOULD be globally unique and SHOULD be a literal address at which at which an authoritative instance of this summary is (or will be) published. This URL can be the target of a canonical reference. It SHALL remain the same when the summary is stored on different servers.",
          0, 1, url);
    case -892481550:
      /* status */ return new Property("status", "code",
          "The status of this summary. Enables tracking the life-cycle of the content.", 0, 1, status);
    case -669707736:
      /* useContext */ return new Property("useContext", "UsageContext",
          "The content was developed with a focus and intent of supporting the contexts that are listed. These contexts may be general categories (gender, age, ...) or may be references to specific programs (insurance plans, studies, ...) and may be used to assist with indexing and searching for appropriate evidence report instances.",
          0, java.lang.Integer.MAX_VALUE, useContext);
    case -1618432855:
      /* identifier */ return new Property("identifier", "Identifier",
          "A formal identifier that is used to identify this EvidenceReport when it is represented in other formats, or referenced in a specification, model, design or an instance.",
          0, java.lang.Integer.MAX_VALUE, identifier);
    case -1007604940:
      /* relatedIdentifier */ return new Property("relatedIdentifier", "Identifier",
          "A formal identifier that is used to identify things closely related to this EvidenceReport.", 0,
          java.lang.Integer.MAX_VALUE, relatedIdentifier);
    case -1706539017:
      /* citeAs[x] */ return new Property("citeAs[x]", "Reference(Citation)|markdown",
          "Citation Resource or display of suggested citation for this report.", 0, 1, citeAs);
    case -1360156695:
      /* citeAs */ return new Property("citeAs[x]", "Reference(Citation)|markdown",
          "Citation Resource or display of suggested citation for this report.", 0, 1, citeAs);
    case 1269009762:
      /* citeAsReference */ return new Property("citeAs[x]", "Reference(Citation)",
          "Citation Resource or display of suggested citation for this report.", 0, 1, citeAs);
    case 456265720:
      /* citeAsMarkdown */ return new Property("citeAs[x]", "markdown",
          "Citation Resource or display of suggested citation for this report.", 0, 1, citeAs);
    case 3575610:
      /* type */ return new Property("type", "CodeableConcept",
          "Specifies the kind of report, such as grouping of classifiers, search results, or human-compiled expression.",
          0, 1, type);
    case 3387378:
      /* note */ return new Property("note", "Annotation", "Used for footnotes and annotations.", 0,
          java.lang.Integer.MAX_VALUE, note);
    case 666807069:
      /* relatedArtifact */ return new Property("relatedArtifact", "RelatedArtifact",
          "Link, description or reference to artifact associated with the report.", 0, java.lang.Integer.MAX_VALUE,
          relatedArtifact);
    case -1867885268:
      /* subject */ return new Property("subject", "",
          "Specifies the subject or focus of the report. Answers \"What is this report about?\".", 0, 1, subject);
    case 1447404028:
      /* publisher */ return new Property("publisher", "string",
          "The name of the organization or individual that published the evidence report.", 0, 1, publisher);
    case 951526432:
      /* contact */ return new Property("contact", "ContactDetail",
          "Contact details to assist a user in finding and communicating with the publisher.", 0,
          java.lang.Integer.MAX_VALUE, contact);
    case -1406328437:
      /* author */ return new Property("author", "ContactDetail",
          "An individiual, organization, or device primarily involved in the creation and maintenance of the content.",
          0, java.lang.Integer.MAX_VALUE, author);
    case -1307827859:
      /* editor */ return new Property("editor", "ContactDetail",
          "An individiual, organization, or device primarily responsible for internal coherence of the content.", 0,
          java.lang.Integer.MAX_VALUE, editor);
    case -261190139:
      /* reviewer */ return new Property("reviewer", "ContactDetail",
          "An individiual, organization, or device primarily responsible for review of some aspect of the content.", 0,
          java.lang.Integer.MAX_VALUE, reviewer);
    case 1740277666:
      /* endorser */ return new Property("endorser", "ContactDetail",
          "An individiual, organization, or device responsible for officially endorsing the content for use in some setting.",
          0, java.lang.Integer.MAX_VALUE, endorser);
    case -7765931:
      /* relatesTo */ return new Property("relatesTo", "",
          "Relationships that this composition has with other compositions or documents that already exist.", 0,
          java.lang.Integer.MAX_VALUE, relatesTo);
    case 1970241253:
      /* section */ return new Property("section", "", "The root of the sections that make up the composition.", 0,
          java.lang.Integer.MAX_VALUE, section);
    default:
      return super.getNamedProperty(_hash, _name, _checkValid);
    }

  }

  @Override
  public Base[] getProperty(int hash, String name, boolean checkValid) throws FHIRException {
    switch (hash) {
    case 116079:
      /* url */ return this.url == null ? new Base[0] : new Base[] { this.url }; // UriType
    case -892481550:
      /* status */ return this.status == null ? new Base[0] : new Base[] { this.status }; // Enumeration<PublicationStatus>
    case -669707736:
      /* useContext */ return this.useContext == null ? new Base[0]
          : this.useContext.toArray(new Base[this.useContext.size()]); // UsageContext
    case -1618432855:
      /* identifier */ return this.identifier == null ? new Base[0]
          : this.identifier.toArray(new Base[this.identifier.size()]); // Identifier
    case -1007604940:
      /* relatedIdentifier */ return this.relatedIdentifier == null ? new Base[0]
          : this.relatedIdentifier.toArray(new Base[this.relatedIdentifier.size()]); // Identifier
    case -1360156695:
      /* citeAs */ return this.citeAs == null ? new Base[0] : new Base[] { this.citeAs }; // DataType
    case 3575610:
      /* type */ return this.type == null ? new Base[0] : new Base[] { this.type }; // CodeableConcept
    case 3387378:
      /* note */ return this.note == null ? new Base[0] : this.note.toArray(new Base[this.note.size()]); // Annotation
    case 666807069:
      /* relatedArtifact */ return this.relatedArtifact == null ? new Base[0]
          : this.relatedArtifact.toArray(new Base[this.relatedArtifact.size()]); // RelatedArtifact
    case -1867885268:
      /* subject */ return this.subject == null ? new Base[0] : new Base[] { this.subject }; // EvidenceReportSubjectComponent
    case 1447404028:
      /* publisher */ return this.publisher == null ? new Base[0] : new Base[] { this.publisher }; // StringType
    case 951526432:
      /* contact */ return this.contact == null ? new Base[0] : this.contact.toArray(new Base[this.contact.size()]); // ContactDetail
    case -1406328437:
      /* author */ return this.author == null ? new Base[0] : this.author.toArray(new Base[this.author.size()]); // ContactDetail
    case -1307827859:
      /* editor */ return this.editor == null ? new Base[0] : this.editor.toArray(new Base[this.editor.size()]); // ContactDetail
    case -261190139:
      /* reviewer */ return this.reviewer == null ? new Base[0] : this.reviewer.toArray(new Base[this.reviewer.size()]); // ContactDetail
    case 1740277666:
      /* endorser */ return this.endorser == null ? new Base[0] : this.endorser.toArray(new Base[this.endorser.size()]); // ContactDetail
    case -7765931:
      /* relatesTo */ return this.relatesTo == null ? new Base[0]
          : this.relatesTo.toArray(new Base[this.relatesTo.size()]); // EvidenceReportRelatesToComponent
    case 1970241253:
      /* section */ return this.section == null ? new Base[0] : this.section.toArray(new Base[this.section.size()]); // SectionComponent
    default:
      return super.getProperty(hash, name, checkValid);
    }

  }

  @Override
  public Base setProperty(int hash, String name, Base value) throws FHIRException {
    switch (hash) {
    case 116079: // url
      this.url = TypeConvertor.castToUri(value); // UriType
      return value;
    case -892481550: // status
      value = new PublicationStatusEnumFactory().fromType(TypeConvertor.castToCode(value));
      this.status = (Enumeration) value; // Enumeration<PublicationStatus>
      return value;
    case -669707736: // useContext
      this.getUseContext().add(TypeConvertor.castToUsageContext(value)); // UsageContext
      return value;
    case -1618432855: // identifier
      this.getIdentifier().add(TypeConvertor.castToIdentifier(value)); // Identifier
      return value;
    case -1007604940: // relatedIdentifier
      this.getRelatedIdentifier().add(TypeConvertor.castToIdentifier(value)); // Identifier
      return value;
    case -1360156695: // citeAs
      this.citeAs = TypeConvertor.castToType(value); // DataType
      return value;
    case 3575610: // type
      this.type = TypeConvertor.castToCodeableConcept(value); // CodeableConcept
      return value;
    case 3387378: // note
      this.getNote().add(TypeConvertor.castToAnnotation(value)); // Annotation
      return value;
    case 666807069: // relatedArtifact
      this.getRelatedArtifact().add(TypeConvertor.castToRelatedArtifact(value)); // RelatedArtifact
      return value;
    case -1867885268: // subject
      this.subject = (EvidenceReportSubjectComponent) value; // EvidenceReportSubjectComponent
      return value;
    case 1447404028: // publisher
      this.publisher = TypeConvertor.castToString(value); // StringType
      return value;
    case 951526432: // contact
      this.getContact().add(TypeConvertor.castToContactDetail(value)); // ContactDetail
      return value;
    case -1406328437: // author
      this.getAuthor().add(TypeConvertor.castToContactDetail(value)); // ContactDetail
      return value;
    case -1307827859: // editor
      this.getEditor().add(TypeConvertor.castToContactDetail(value)); // ContactDetail
      return value;
    case -261190139: // reviewer
      this.getReviewer().add(TypeConvertor.castToContactDetail(value)); // ContactDetail
      return value;
    case 1740277666: // endorser
      this.getEndorser().add(TypeConvertor.castToContactDetail(value)); // ContactDetail
      return value;
    case -7765931: // relatesTo
      this.getRelatesTo().add((EvidenceReportRelatesToComponent) value); // EvidenceReportRelatesToComponent
      return value;
    case 1970241253: // section
      this.getSection().add((SectionComponent) value); // SectionComponent
      return value;
    default:
      return super.setProperty(hash, name, value);
    }

  }

  @Override
  public Base setProperty(String name, Base value) throws FHIRException {
    if (name.equals("url")) {
      this.url = TypeConvertor.castToUri(value); // UriType
    } else if (name.equals("status")) {
      value = new PublicationStatusEnumFactory().fromType(TypeConvertor.castToCode(value));
      this.status = (Enumeration) value; // Enumeration<PublicationStatus>
    } else if (name.equals("useContext")) {
      this.getUseContext().add(TypeConvertor.castToUsageContext(value));
    } else if (name.equals("identifier")) {
      this.getIdentifier().add(TypeConvertor.castToIdentifier(value));
    } else if (name.equals("relatedIdentifier")) {
      this.getRelatedIdentifier().add(TypeConvertor.castToIdentifier(value));
    } else if (name.equals("citeAs[x]")) {
      this.citeAs = TypeConvertor.castToType(value); // DataType
    } else if (name.equals("type")) {
      this.type = TypeConvertor.castToCodeableConcept(value); // CodeableConcept
    } else if (name.equals("note")) {
      this.getNote().add(TypeConvertor.castToAnnotation(value));
    } else if (name.equals("relatedArtifact")) {
      this.getRelatedArtifact().add(TypeConvertor.castToRelatedArtifact(value));
    } else if (name.equals("subject")) {
      this.subject = (EvidenceReportSubjectComponent) value; // EvidenceReportSubjectComponent
    } else if (name.equals("publisher")) {
      this.publisher = TypeConvertor.castToString(value); // StringType
    } else if (name.equals("contact")) {
      this.getContact().add(TypeConvertor.castToContactDetail(value));
    } else if (name.equals("author")) {
      this.getAuthor().add(TypeConvertor.castToContactDetail(value));
    } else if (name.equals("editor")) {
      this.getEditor().add(TypeConvertor.castToContactDetail(value));
    } else if (name.equals("reviewer")) {
      this.getReviewer().add(TypeConvertor.castToContactDetail(value));
    } else if (name.equals("endorser")) {
      this.getEndorser().add(TypeConvertor.castToContactDetail(value));
    } else if (name.equals("relatesTo")) {
      this.getRelatesTo().add((EvidenceReportRelatesToComponent) value);
    } else if (name.equals("section")) {
      this.getSection().add((SectionComponent) value);
    } else
      return super.setProperty(name, value);
    return value;
  }

  @Override
  public void removeChild(String name, Base value) throws FHIRException {
    if (name.equals("url")) {
      this.url = null;
    } else if (name.equals("status")) {
      this.status = null;
    } else if (name.equals("useContext")) {
      this.getUseContext().remove(value);
    } else if (name.equals("identifier")) {
      this.getIdentifier().remove(value);
    } else if (name.equals("relatedIdentifier")) {
      this.getRelatedIdentifier().remove(value);
    } else if (name.equals("citeAs[x]")) {
      this.citeAs = null;
    } else if (name.equals("type")) {
      this.type = null;
    } else if (name.equals("note")) {
      this.getNote().remove(value);
    } else if (name.equals("relatedArtifact")) {
      this.getRelatedArtifact().remove(value);
    } else if (name.equals("subject")) {
      this.subject = (EvidenceReportSubjectComponent) value; // EvidenceReportSubjectComponent
    } else if (name.equals("publisher")) {
      this.publisher = null;
    } else if (name.equals("contact")) {
      this.getContact().remove(value);
    } else if (name.equals("author")) {
      this.getAuthor().remove(value);
    } else if (name.equals("editor")) {
      this.getEditor().remove(value);
    } else if (name.equals("reviewer")) {
      this.getReviewer().remove(value);
    } else if (name.equals("endorser")) {
      this.getEndorser().remove(value);
    } else if (name.equals("relatesTo")) {
      this.getRelatesTo().remove((EvidenceReportRelatesToComponent) value);
    } else if (name.equals("section")) {
      this.getSection().remove((SectionComponent) value);
    } else
      super.removeChild(name, value);
    
  }

  @Override
  public Base makeProperty(int hash, String name) throws FHIRException {
    switch (hash) {
    case 116079:
      return getUrlElement();
    case -892481550:
      return getStatusElement();
    case -669707736:
      return addUseContext();
    case -1618432855:
      return addIdentifier();
    case -1007604940:
      return addRelatedIdentifier();
    case -1706539017:
      return getCiteAs();
    case -1360156695:
      return getCiteAs();
    case 3575610:
      return getType();
    case 3387378:
      return addNote();
    case 666807069:
      return addRelatedArtifact();
    case -1867885268:
      return getSubject();
    case 1447404028:
      return getPublisherElement();
    case 951526432:
      return addContact();
    case -1406328437:
      return addAuthor();
    case -1307827859:
      return addEditor();
    case -261190139:
      return addReviewer();
    case 1740277666:
      return addEndorser();
    case -7765931:
      return addRelatesTo();
    case 1970241253:
      return addSection();
    default:
      return super.makeProperty(hash, name);
    }

  }

  @Override
  public String[] getTypesForProperty(int hash, String name) throws FHIRException {
    switch (hash) {
    case 116079:
      /* url */ return new String[] { "uri" };
    case -892481550:
      /* status */ return new String[] { "code" };
    case -669707736:
      /* useContext */ return new String[] { "UsageContext" };
    case -1618432855:
      /* identifier */ return new String[] { "Identifier" };
    case -1007604940:
      /* relatedIdentifier */ return new String[] { "Identifier" };
    case -1360156695:
      /* citeAs */ return new String[] { "Reference", "markdown" };
    case 3575610:
      /* type */ return new String[] { "CodeableConcept" };
    case 3387378:
      /* note */ return new String[] { "Annotation" };
    case 666807069:
      /* relatedArtifact */ return new String[] { "RelatedArtifact" };
    case -1867885268:
      /* subject */ return new String[] {};
    case 1447404028:
      /* publisher */ return new String[] { "string" };
    case 951526432:
      /* contact */ return new String[] { "ContactDetail" };
    case -1406328437:
      /* author */ return new String[] { "ContactDetail" };
    case -1307827859:
      /* editor */ return new String[] { "ContactDetail" };
    case -261190139:
      /* reviewer */ return new String[] { "ContactDetail" };
    case 1740277666:
      /* endorser */ return new String[] { "ContactDetail" };
    case -7765931:
      /* relatesTo */ return new String[] {};
    case 1970241253:
      /* section */ return new String[] {};
    default:
      return super.getTypesForProperty(hash, name);
    }

  }

  @Override
  public Base addChild(String name) throws FHIRException {
    if (name.equals("url")) {
      throw new FHIRException("Cannot call addChild on a singleton property EvidenceReport.url");
    } else if (name.equals("status")) {
      throw new FHIRException("Cannot call addChild on a singleton property EvidenceReport.status");
    } else if (name.equals("useContext")) {
      return addUseContext();
    } else if (name.equals("identifier")) {
      return addIdentifier();
    } else if (name.equals("relatedIdentifier")) {
      return addRelatedIdentifier();
    } else if (name.equals("citeAsReference")) {
      this.citeAs = new Reference();
      return this.citeAs;
    } else if (name.equals("citeAsMarkdown")) {
      this.citeAs = new MarkdownType();
      return this.citeAs;
    } else if (name.equals("type")) {
      this.type = new CodeableConcept();
      return this.type;
    } else if (name.equals("note")) {
      return addNote();
    } else if (name.equals("relatedArtifact")) {
      return addRelatedArtifact();
    } else if (name.equals("subject")) {
      this.subject = new EvidenceReportSubjectComponent();
      return this.subject;
    } else if (name.equals("publisher")) {
      throw new FHIRException("Cannot call addChild on a singleton property EvidenceReport.publisher");
    } else if (name.equals("contact")) {
      return addContact();
    } else if (name.equals("author")) {
      return addAuthor();
    } else if (name.equals("editor")) {
      return addEditor();
    } else if (name.equals("reviewer")) {
      return addReviewer();
    } else if (name.equals("endorser")) {
      return addEndorser();
    } else if (name.equals("relatesTo")) {
      return addRelatesTo();
    } else if (name.equals("section")) {
      return addSection();
    } else
      return super.addChild(name);
  }

  public String fhirType() {
    return "EvidenceReport";

  }

  public EvidenceReport copy() {
    EvidenceReport dst = new EvidenceReport();
    copyValues(dst);
    return dst;
  }

  public void copyValues(EvidenceReport dst) {
    super.copyValues(dst);
    dst.url = url == null ? null : url.copy();
    dst.status = status == null ? null : status.copy();
    if (useContext != null) {
      dst.useContext = new ArrayList<UsageContext>();
      for (UsageContext i : useContext)
        dst.useContext.add(i.copy());
    }
    ;
    if (identifier != null) {
      dst.identifier = new ArrayList<Identifier>();
      for (Identifier i : identifier)
        dst.identifier.add(i.copy());
    }
    ;
    if (relatedIdentifier != null) {
      dst.relatedIdentifier = new ArrayList<Identifier>();
      for (Identifier i : relatedIdentifier)
        dst.relatedIdentifier.add(i.copy());
    }
    ;
    dst.citeAs = citeAs == null ? null : citeAs.copy();
    dst.type = type == null ? null : type.copy();
    if (note != null) {
      dst.note = new ArrayList<Annotation>();
      for (Annotation i : note)
        dst.note.add(i.copy());
    }
    ;
    if (relatedArtifact != null) {
      dst.relatedArtifact = new ArrayList<RelatedArtifact>();
      for (RelatedArtifact i : relatedArtifact)
        dst.relatedArtifact.add(i.copy());
    }
    ;
    dst.subject = subject == null ? null : subject.copy();
    dst.publisher = publisher == null ? null : publisher.copy();
    if (contact != null) {
      dst.contact = new ArrayList<ContactDetail>();
      for (ContactDetail i : contact)
        dst.contact.add(i.copy());
    }
    ;
    if (author != null) {
      dst.author = new ArrayList<ContactDetail>();
      for (ContactDetail i : author)
        dst.author.add(i.copy());
    }
    ;
    if (editor != null) {
      dst.editor = new ArrayList<ContactDetail>();
      for (ContactDetail i : editor)
        dst.editor.add(i.copy());
    }
    ;
    if (reviewer != null) {
      dst.reviewer = new ArrayList<ContactDetail>();
      for (ContactDetail i : reviewer)
        dst.reviewer.add(i.copy());
    }
    ;
    if (endorser != null) {
      dst.endorser = new ArrayList<ContactDetail>();
      for (ContactDetail i : endorser)
        dst.endorser.add(i.copy());
    }
    ;
    if (relatesTo != null) {
      dst.relatesTo = new ArrayList<EvidenceReportRelatesToComponent>();
      for (EvidenceReportRelatesToComponent i : relatesTo)
        dst.relatesTo.add(i.copy());
    }
    ;
    if (section != null) {
      dst.section = new ArrayList<SectionComponent>();
      for (SectionComponent i : section)
        dst.section.add(i.copy());
    }
    ;
  }

  protected EvidenceReport typedCopy() {
    return copy();
  }

  @Override
  public boolean equalsDeep(Base other_) {
    if (!super.equalsDeep(other_))
      return false;
    if (!(other_ instanceof EvidenceReport))
      return false;
    EvidenceReport o = (EvidenceReport) other_;
    return compareDeep(url, o.url, true) && compareDeep(status, o.status, true)
        && compareDeep(useContext, o.useContext, true) && compareDeep(identifier, o.identifier, true)
        && compareDeep(relatedIdentifier, o.relatedIdentifier, true) && compareDeep(citeAs, o.citeAs, true)
        && compareDeep(type, o.type, true) && compareDeep(note, o.note, true)
        && compareDeep(relatedArtifact, o.relatedArtifact, true) && compareDeep(subject, o.subject, true)
        && compareDeep(publisher, o.publisher, true) && compareDeep(contact, o.contact, true)
        && compareDeep(author, o.author, true) && compareDeep(editor, o.editor, true)
        && compareDeep(reviewer, o.reviewer, true) && compareDeep(endorser, o.endorser, true)
        && compareDeep(relatesTo, o.relatesTo, true) && compareDeep(section, o.section, true);
  }

  @Override
  public boolean equalsShallow(Base other_) {
    if (!super.equalsShallow(other_))
      return false;
    if (!(other_ instanceof EvidenceReport))
      return false;
    EvidenceReport o = (EvidenceReport) other_;
    return compareValues(url, o.url, true) && compareValues(status, o.status, true)
        && compareValues(publisher, o.publisher, true);
  }

  public boolean isEmpty() {
    return super.isEmpty()
        && ca.uhn.fhir.util.ElementUtil.isEmpty(url, status, useContext, identifier, relatedIdentifier, citeAs, type,
            note, relatedArtifact, subject, publisher, contact, author, editor, reviewer, endorser, relatesTo, section);
  }

  @Override
  public ResourceType getResourceType() {
    return ResourceType.EvidenceReport;
  }

  /**
   * Search parameter: <b>context-quantity</b>
   * <p>
   * Description: <b>A quantity- or range-valued use context assigned to the
   * evidence report</b><br>
   * Type: <b>quantity</b><br>
   * Path: <b>(EvidenceReport.useContext.value as Quantity) |
   * (EvidenceReport.useContext.value as Range)</b><br>
   * </p>
   */
  @SearchParamDefinition(name = "context-quantity", path = "(EvidenceReport.useContext.value as Quantity) | (EvidenceReport.useContext.value as Range)", description = "A quantity- or range-valued use context assigned to the evidence report", type = "quantity")
  public static final String SP_CONTEXT_QUANTITY = "context-quantity";
  /**
   * <b>Fluent Client</b> search parameter constant for <b>context-quantity</b>
   * <p>
   * Description: <b>A quantity- or range-valued use context assigned to the
   * evidence report</b><br>
   * Type: <b>quantity</b><br>
   * Path: <b>(EvidenceReport.useContext.value as Quantity) |
   * (EvidenceReport.useContext.value as Range)</b><br>
   * </p>
   */
  public static final ca.uhn.fhir.rest.gclient.QuantityClientParam CONTEXT_QUANTITY = new ca.uhn.fhir.rest.gclient.QuantityClientParam(
      SP_CONTEXT_QUANTITY);

  /**
   * Search parameter: <b>context-type-quantity</b>
   * <p>
   * Description: <b>A use context type and quantity- or range-based value
   * assigned to the evidence report</b><br>
   * Type: <b>composite</b><br>
   * Path: <b>EvidenceReport.useContext</b><br>
   * </p>
   */
  @SearchParamDefinition(name = "context-type-quantity", path = "EvidenceReport.useContext", description = "A use context type and quantity- or range-based value assigned to the evidence report", type = "composite", compositeOf = {
      "context-type", "context-quantity" })
  public static final String SP_CONTEXT_TYPE_QUANTITY = "context-type-quantity";
  /**
   * <b>Fluent Client</b> search parameter constant for
   * <b>context-type-quantity</b>
   * <p>
   * Description: <b>A use context type and quantity- or range-based value
   * assigned to the evidence report</b><br>
   * Type: <b>composite</b><br>
   * Path: <b>EvidenceReport.useContext</b><br>
   * </p>
   */
  public static final ca.uhn.fhir.rest.gclient.CompositeClientParam<ca.uhn.fhir.rest.gclient.TokenClientParam, ca.uhn.fhir.rest.gclient.QuantityClientParam> CONTEXT_TYPE_QUANTITY = new ca.uhn.fhir.rest.gclient.CompositeClientParam<ca.uhn.fhir.rest.gclient.TokenClientParam, ca.uhn.fhir.rest.gclient.QuantityClientParam>(
      SP_CONTEXT_TYPE_QUANTITY);

  /**
   * Search parameter: <b>context-type-value</b>
   * <p>
   * Description: <b>A use context type and value assigned to the evidence
   * report</b><br>
   * Type: <b>composite</b><br>
   * Path: <b>EvidenceReport.useContext</b><br>
   * </p>
   */
  @SearchParamDefinition(name = "context-type-value", path = "EvidenceReport.useContext", description = "A use context type and value assigned to the evidence report", type = "composite", compositeOf = {
      "context-type", "context" })
  public static final String SP_CONTEXT_TYPE_VALUE = "context-type-value";
  /**
   * <b>Fluent Client</b> search parameter constant for <b>context-type-value</b>
   * <p>
   * Description: <b>A use context type and value assigned to the evidence
   * report</b><br>
   * Type: <b>composite</b><br>
   * Path: <b>EvidenceReport.useContext</b><br>
   * </p>
   */
  public static final ca.uhn.fhir.rest.gclient.CompositeClientParam<ca.uhn.fhir.rest.gclient.TokenClientParam, ca.uhn.fhir.rest.gclient.TokenClientParam> CONTEXT_TYPE_VALUE = new ca.uhn.fhir.rest.gclient.CompositeClientParam<ca.uhn.fhir.rest.gclient.TokenClientParam, ca.uhn.fhir.rest.gclient.TokenClientParam>(
      SP_CONTEXT_TYPE_VALUE);

  /**
   * Search parameter: <b>context-type</b>
   * <p>
   * Description: <b>A type of use context assigned to the evidence report</b><br>
   * Type: <b>token</b><br>
   * Path: <b>EvidenceReport.useContext.code</b><br>
   * </p>
   */
  @SearchParamDefinition(name = "context-type", path = "EvidenceReport.useContext.code", description = "A type of use context assigned to the evidence report", type = "token")
  public static final String SP_CONTEXT_TYPE = "context-type";
  /**
   * <b>Fluent Client</b> search parameter constant for <b>context-type</b>
   * <p>
   * Description: <b>A type of use context assigned to the evidence report</b><br>
   * Type: <b>token</b><br>
   * Path: <b>EvidenceReport.useContext.code</b><br>
   * </p>
   */
  public static final ca.uhn.fhir.rest.gclient.TokenClientParam CONTEXT_TYPE = new ca.uhn.fhir.rest.gclient.TokenClientParam(
      SP_CONTEXT_TYPE);

  /**
   * Search parameter: <b>context</b>
   * <p>
   * Description: <b>A use context assigned to the evidence report</b><br>
   * Type: <b>token</b><br>
   * Path: <b>(EvidenceReport.useContext.value as CodeableConcept)</b><br>
   * </p>
   */
  @SearchParamDefinition(name = "context", path = "(EvidenceReport.useContext.value as CodeableConcept)", description = "A use context assigned to the evidence report", type = "token")
  public static final String SP_CONTEXT = "context";
  /**
   * <b>Fluent Client</b> search parameter constant for <b>context</b>
   * <p>
   * Description: <b>A use context assigned to the evidence report</b><br>
   * Type: <b>token</b><br>
   * Path: <b>(EvidenceReport.useContext.value as CodeableConcept)</b><br>
   * </p>
   */
  public static final ca.uhn.fhir.rest.gclient.TokenClientParam CONTEXT = new ca.uhn.fhir.rest.gclient.TokenClientParam(
      SP_CONTEXT);

  /**
   * Search parameter: <b>identifier</b>
   * <p>
   * Description: <b>External identifier for the evidence report</b><br>
   * Type: <b>token</b><br>
   * Path: <b>EvidenceReport.identifier</b><br>
   * </p>
   */
  @SearchParamDefinition(name = "identifier", path = "EvidenceReport.identifier", description = "External identifier for the evidence report", type = "token")
  public static final String SP_IDENTIFIER = "identifier";
  /**
   * <b>Fluent Client</b> search parameter constant for <b>identifier</b>
   * <p>
   * Description: <b>External identifier for the evidence report</b><br>
   * Type: <b>token</b><br>
   * Path: <b>EvidenceReport.identifier</b><br>
   * </p>
   */
  public static final ca.uhn.fhir.rest.gclient.TokenClientParam IDENTIFIER = new ca.uhn.fhir.rest.gclient.TokenClientParam(
      SP_IDENTIFIER);

  /**
   * Search parameter: <b>publisher</b>
   * <p>
   * Description: <b>Name of the publisher of the evidence report</b><br>
   * Type: <b>string</b><br>
   * Path: <b>EvidenceReport.publisher</b><br>
   * </p>
   */
  @SearchParamDefinition(name = "publisher", path = "EvidenceReport.publisher", description = "Name of the publisher of the evidence report", type = "string")
  public static final String SP_PUBLISHER = "publisher";
  /**
   * <b>Fluent Client</b> search parameter constant for <b>publisher</b>
   * <p>
   * Description: <b>Name of the publisher of the evidence report</b><br>
   * Type: <b>string</b><br>
   * Path: <b>EvidenceReport.publisher</b><br>
   * </p>
   */
  public static final ca.uhn.fhir.rest.gclient.StringClientParam PUBLISHER = new ca.uhn.fhir.rest.gclient.StringClientParam(
      SP_PUBLISHER);

  /**
   * Search parameter: <b>status</b>
   * <p>
   * Description: <b>The current status of the evidence report</b><br>
   * Type: <b>token</b><br>
   * Path: <b>EvidenceReport.status</b><br>
   * </p>
   */
  @SearchParamDefinition(name = "status", path = "EvidenceReport.status", description = "The current status of the evidence report", type = "token")
  public static final String SP_STATUS = "status";
  /**
   * <b>Fluent Client</b> search parameter constant for <b>status</b>
   * <p>
   * Description: <b>The current status of the evidence report</b><br>
   * Type: <b>token</b><br>
   * Path: <b>EvidenceReport.status</b><br>
   * </p>
   */
  public static final ca.uhn.fhir.rest.gclient.TokenClientParam STATUS = new ca.uhn.fhir.rest.gclient.TokenClientParam(
      SP_STATUS);

  /**
   * Search parameter: <b>url</b>
   * <p>
   * Description: <b>The uri that identifies the evidence report</b><br>
   * Type: <b>uri</b><br>
   * Path: <b>EvidenceReport.url</b><br>
   * </p>
   */
  @SearchParamDefinition(name = "url", path = "EvidenceReport.url", description = "The uri that identifies the evidence report", type = "uri")
  public static final String SP_URL = "url";
  /**
   * <b>Fluent Client</b> search parameter constant for <b>url</b>
   * <p>
   * Description: <b>The uri that identifies the evidence report</b><br>
   * Type: <b>uri</b><br>
   * Path: <b>EvidenceReport.url</b><br>
   * </p>
   */
  public static final ca.uhn.fhir.rest.gclient.UriClientParam URL = new ca.uhn.fhir.rest.gclient.UriClientParam(SP_URL);

}
